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

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");
相关推荐
Tigshop开源商城17 分钟前
『物流设置+SEO优化』Tigshop开源商城系统 JAVA v5.8.26 版本更新!
java·开源商城系统·tigshop
Tigshop开源商城2 小时前
『订单税率+收货地址校验国家字段』功能上新|跨境运营更高效,Tigshop开源商城系统 JAVA v5.8.23 版本更新
java·开源商城系统·tigshop
不会敲代码12 小时前
手写 Zustand:三十分钟带你搞懂状态管理库的核心原理
前端·javascript·源码
神奇的程序员2 小时前
重构了自己5年前写的截图插件
前端·javascript·架构
REDcker2 小时前
C++变量存储与ELF段布局详解 从const全局到rodata与nm_readelf验证实践
java·c++·面试
UXbot4 小时前
一人独立交付 UI + 前端:AI 驱动 UI 设计工具的五大功能模块深度评测
前端·低代码·ui·设计模式·交互
kobesdu4 小时前
【ROS2实战笔记-19】ROS2 生命周期节点的启动顺序、状态转换陷阱与热备方案
java·前端·笔记·机器人·ros·ros2
诚实可靠王大锤4 小时前
React Native 输入框与按钮焦点冲突解决方案(rn版本0.70.3)
前端·javascript·react native·react.js
neo_Ggx234 小时前
Maven 版本管理详解:SNAPSHOT、Release 与 Nexus 仓库的区别和影响
java·maven
matlabgoodboy4 小时前
软件开发定制小程序APP帮代做java代码代编写C语言设计python编程
java·c语言·小程序