vue 动态添加/删除dom元素节点的操作代码

 更新时间:2022年12月06日 10:05:46   作者:Mr.Meng_95  
这篇文章主要介绍了vue 动态添加/删除dom元素,需要在点击添加时,增加一行key/value的输入框;点击垃圾桶图标时,删除对应行,本文结合实例代码给大家讲解的非常详细,需要的朋友可以参考下

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中响应式解构props的使用

    Vue3中响应式解构props的使用

    本文主要介绍了Vue3中响应式解构props的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-11-11
  • Vue.js 2.x之组件的定义和注册图文详解

    Vue.js 2.x之组件的定义和注册图文详解

    组件Component是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码,这篇文章主要介绍了Vue.js 2.x:组件的定义和注册,需要的朋友可以参考下
    2018-06-06
  • vue中el-tree结合el-switch实现开关状态切换

    vue中el-tree结合el-switch实现开关状态切换

    本文主要介绍了vue中el-tree结合el-switch实现开关状态切换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • 详解Vue的options

    详解Vue的options

    options顾名思义是选项的意思,或称为构造选项。是在创建vue实例时传入的参数,是一个对象。该对象包含哪些属性?每个属性都是什么含义?本篇文章就来带大家详细了解其中的奥秘
    2021-05-05
  • Vue.js学习之计算属性

    Vue.js学习之计算属性

    Vue.js 的内联表达式非常方便,但它最合适的使用场景是简单的布尔操作或字符串拼接。如果涉及更复杂的逻辑,你应该使用计算属性。下面这篇文章主要给大家介绍了Vue.js中的计算属性,需要的朋友可以参考借鉴,一起来看看吧。
    2017-01-01
  • Vue3实现canvas画布组件自定义画板实例代码

    Vue3实现canvas画布组件自定义画板实例代码

    Vue Canvas是一个基于Vue.js的轻量级画板组件,旨在提供一个简易的画布功能,用户可以在网页上进行自由绘图,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-09-09
  • Vue3(ts)使用vee-validate表单校验,自定义全局验证规则说明

    Vue3(ts)使用vee-validate表单校验,自定义全局验证规则说明

    这篇文章主要介绍了Vue3(ts)使用vee-validate表单校验,自定义全局验证规则说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • Vue拿到二进制流图片如何转为正常图片并显示

    Vue拿到二进制流图片如何转为正常图片并显示

    这篇文章主要介绍了Vue拿到二进制流图片如何转为正常图片并显示,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • Vue中如何设置全局的cookie对象

    Vue中如何设置全局的cookie对象

    这篇文章主要介绍了Vue中如何设置全局的cookie对象,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • Antd-vue Table组件添加Click事件,实现点击某行数据教程

    Antd-vue Table组件添加Click事件,实现点击某行数据教程

    这篇文章主要介绍了Antd-vue Table组件添加Click事件,实现点击某行数据教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11

最新评论