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

html 复制代码
    <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>
javascript 复制代码
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");
相关推荐
tao3556671 分钟前
VS Code登录codex,报错(os error 10013)
java·服务器·前端
军军君014 分钟前
Three.js基础功能学习七:加载器与管理器
开发语言·前端·javascript·学习·3d·threejs·三维
JarvanMo7 分钟前
情迷服务器驱动 UI:我在 Flutter 开发中的爱与哀愁
前端
信创天地7 分钟前
核心系统去 “O” 攻坚:信创数据库迁移的双轨运行与数据一致性保障方案
java·大数据·数据库·金融·架构·政务
小杰帅气8 分钟前
神秘的环境变量和进程地址空间
linux·运维·服务器
tzy2339 分钟前
分享一个 HTTP(S) 代理&抓包工具,拦截和Mock Web客户端请求和服务端响应
前端·网络协议·http
mjhcsp10 分钟前
C++ AC 自动机:原理、实现与应用全解析
java·开发语言·c++·ac 自动机
胖咕噜的稞达鸭11 分钟前
进程间的通信(1)(理解管道特性,匿名命名管道,进程池,systeam V共享内存是什么及优势)重点理解代码!
linux·运维·服务器·数据库
huihuihuanhuan.xin11 分钟前
后端八股之java并发编程
java·开发语言
茶本无香14 分钟前
设计模式之二—原型模式:灵活的对象克隆机制
java·设计模式·原型模式