表格新增行,可编辑删除行

    <button type="button" style="margin-bottom:10px;" class="btn btn-primary" @click="addAddress"><i
            class="fa fa-plus"></i></button>
    <table class="table table-bordered">
        <tbody>
            <tr>
                <th style="width: 140px; text-align:center;">地址类型</th>
                <th>地址信息</th>
                <th style="width: 120px; text-align:center;">邮编</th>
                <th style="width: 120px; text-align:center;">操作</th>
            </tr>
            <tr v-for="(item, index) in addressList" :key="index">
                <td>
                    <span v-if="!item.isEdit">{
  {item.type}}</span>
                    <input v-else v-model="item.type" class="form-control" placeholder="请输入地址类型">
                </td>
                <td>
                    <span v-if="!item.isEdit">{
  {item.address}}</span>
                    <input v-else v-model="item.address" class="form-control" placeholder="请输入地址">
                </td>
                <td>
                    <span v-if="!item.isEdit">{
  {item.zipCode}}</span>
                    <input v-else v-model="item.zipCode" class="form-control" placeholder="请输入邮编">
                </td>
                <td>
                    <button v-if="item.isEdit" type="button" class="btn btn-default"
                        @click="handleEditAddress(index, false)"><i class="fa fa-check"></i></button>
                    <button v-else type="button" class="btn btn-default" @click="handleEditAddress(index, true)"><i
                            class="fa fa-edit"></i></button>
                    <button type="button" class="btn btn-default" style="margin-left:10px;"
                        @click="delAddress(index)"><i class="fa fa-times"></i></button>
                </td>
            </tr>
        </tbody>
    </table>
const VueApp = {
	setup() {
		const empiData = Vue.ref({
		
		});
		const addressList = Vue.ref([
			{
				"type": "工作单位地址",
				"address": "山东省青岛市市北区福州北路浮山后街道23号",
				"zipCode": "26000",
				"isEdit": false
			},
			{
				"type": "户口地址",
				"address": "山东省青岛市市北区福州北路浮山",
				"zipCode": "26001",
				"isEdit": false
			},
			{
				"type": "籍贯地址",
				"address": "山东省青岛市市北区福州北路浮山",
				"zipCode": "26001",
				"isEdit": false
			}
		]);
		const addAddress = () => {
			for(let i in addressList.value){
				addressList.value[i].isEdit = false;
			}
			addressList.value.push({
				"type": "",
				"address": "",
				"zipCode": "",
				"isEdit": true
			});
		};
		const delAddress = (index) => {
		  addressList.value.splice(index, 1);
		};
		const handleEditAddress = (index, flag) => {
		  addressList.value[index].isEdit = flag;
		};
		return {
			empiData,
			addressList,
			handleEditAddress,
			addAddress,
			delAddress
		};
	},
};
const app = Vue.createApp(VueApp);
app.use(naive);
app.mount("#vue-app");

最近更新

  1. TCP协议是安全的吗?

    2024-02-07 17:58:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-07 17:58:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-07 17:58:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-07 17:58:01       20 阅读

热门阅读

  1. 经典网络面试题(4)

    2024-02-07 17:58:01       31 阅读
  2. CSS transition(过渡效果)详解

    2024-02-07 17:58:01       28 阅读
  3. 笔记---贪心---区间问题

    2024-02-07 17:58:01       30 阅读
  4. Debezium发布历史113

    2024-02-07 17:58:01       26 阅读
  5. git命令

    git命令

    2024-02-07 17:58:01      27 阅读
  6. Ubuntu23.04编译VLC3.0.20的各种错误处理

    2024-02-07 17:58:01       34 阅读