vue 动态添加/删除dom元素节点的操作代码
vue 动态添加/删除dom元素
需要在点击添加时,增加一行key/value的输入框;点击垃圾桶图标时,删除对应行
效果图
核心:使用v-for来管理添加行数量。
<div class="addPanel"> <div v-for="num in ParamsNum" :key="num"> <el-row style="margin-bottom: 10px;"> <el-col :span="9"> <el-input v-model="temp.params[num].key" placeholder="key" size="small"/> </el-col> <el-col :span="10"> <el-input style="margin-left: 10px;" v-model="temp.params[num].value" placeholder="value" size="small"/> </el-col> <el-col :span="4" style="text-align: center;line-height: 30px;"> <i class="el-icon-delete-solid" style="color:red;cursor: pointer;" @click="handleDeleteParams(num)"></i> </el-col> </el-row> </div> <span class="addBlock" @click="handleAddParams"><i class="el-icon-plus" style="font-weight: bold"></i> 添加请求参数</span> </div>
data() { return { temp: { params: [{key:'',value:''}] }, ParamsNum: 0 } }, methods: { handleAddParams() { this.temp.params.push({key:'',value:''}) this.ParamsNum++ }, handleDeleteParams(num) { this.ParamsNum-- this.temp.params.splice(num,1) } }
.addPanel { margin-left: 10px; width: 98%; min-height: 70px; border: 2px solid #e4e7ed; border-radius: 15px; padding: 10px; } .addBlock { line-height: 50px; border: 1px #dddddd dashed; padding: 10px; cursor: pointer; }
扩展:
vue中删除dom元素节点
document.querySelectorAll(…).remove is not a function"
document.querySelectorAll('.esedbox .triangle_b').remove()
因为document.querySelectorAll(‘.esedbox .triangle_b’)返回的不是数组,而是类数组,不能用remove方法(remove方法是dom元素节点的方法)
Array.from()方法主要用于将两类对象(类似数组的对象[array-like object]和可遍历对象[iterable])转为真正的数组。
正确的写法:
const cleardom = document.querySelectorAll('.esedbox .triangle_b, .triangle_p') Array.from(cleardom).forEach((item) => { item.remove() })
到此这篇关于vue 动态添加/删除dom元素的文章就介绍到这了,更多相关vue删除dom元素内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue3.2 新增指令 v-memo 用法详解(提高性能利器)
v-memo 接受一个依赖的数组,依赖的数组变化,v-memo 所对应的 DOM 包括子集将会重新渲染,这篇文章主要介绍了Vue3.2 新增指令 v-memo 用法,提高性能的又一利器,需要的朋友可以参考下2022-09-09antd form表单使用setFildesValue 赋值失效的解决
这篇文章主要介绍了antd form表单使用setFildesValue 赋值失效的解决方案,具有很好的参考价值,希望对大家有所帮助。2023-04-04vue3中vite的@路径别名与path中resolve实例详解
这篇文章主要给大家介绍了关于vue3中vite的@路径别名与path中resolve的相关资料,文中通过实例代码介绍的非常详细,对大家学习或者使用vue具有一定的参考学习价值,需要的朋友可以参考下2023-02-02
最新评论