vue 实现在同一界面实现组件的动态添加和删除功能


Posted in Javascript onJune 16, 2020

 1.插入静态组件,将自己想要循环的组件显示在页面上,利用v-for进行循环操作,操作包括增删。

//所有要显示的子组件,写在一个li标签,有 v-for循环。
  <li v-for="(item, index) in questionList" v-bind:key="index">
          <el-row :gutter="20">
            <el-col offset="2" :span="4">
              <el-select
                size="small"
                v-model="chooseValue"
                multiple
                placeholdr="请选择试题类型"
                style="width:200px;margin-left:-40px"
              >
                <el-option :value="item.mineStatusValue" style="height:auto">
                  <el-tree
                    :data="data"
                    node-key="id"
                    :props="defaultProps"
                    @node-click="handleNodeClick"
                  ></el-tree>
                </el-option>
              </el-select>
            </el-col>
            <el-col offset="3" :span="3">
              <el-select
                style="margin-left:-30px"
                size="small"
                v-model="item.value"
                placeholder="请选择">
                <el-option
                  v-for="item in questionoptions"
                  :key="item.value"
                  :label="item.label"
                  :value="item.value"
                ></el-option>
              </el-select>
            </el-col>
            <el-col offset="2" :span="4">
              <el-input style="width:45px;" size="small" v-model="count">
                {{ item.count }}
              </el-input>
              <label> /0 </label>
            </el-col>
            <el-col :span="6">
              <el-input style="width:45px;" size="small" v-model="sourcess">
                {{ item.sourcess }}
              </el-input>
              <label>  </label>
              <!-- 在i标签设置删除按钮,运用splice函数。 -->
              <i class="el-icon-remove-outline"
                style="margin-left:20px"
                @click="questionList.splice(index, 1)"
              ></i>

2.增

在方法添加按钮,在点击添加按钮的时候将需要的参数传进数组,遍历数组,达到组件渲染。

//添加试题,组件循环显示
    addQuestion() {
      console.log("添加试题");
      this.questionList.unshift({
        mineStatusValue: this.mineStatusValue,
        questionoptions: this.questionoptions,
        count: this.count,
        sourcess: this.sourcess,
      });
    },

3.删

根据选中的组件,获取它的索引,根据下标把它删掉,更新数组,重选渲染组件。

注:删除的时候用到了splic函数,具体的使用可以自己了解。

<i class="el-icon-remove-outline"
  style="margin-left:20px"
  @click="questionList.splice(index, 1)">
</i>

4.效果

vue 实现在同一界面实现组件的动态添加和删除功能

PS:在Vue组件上动态添加和删除属性方法

如下所示:

在组件上添加属性 this.$set(this.data,"obj",value');

删除属性this.$delete(this.data,"obj",value');

总结

到此这篇关于vue 实现在同一界面实现组件的动态添加和删除的文章就介绍到这了,更多相关vue 组件动态添加和删除内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
优化网页之快速的呈现我们的网页
Jun 29 Javascript
js行号显示的文本框实现效果(兼容多种浏览器 )
Oct 23 Javascript
仅30行代码实现Javascript中的MVC
Feb 15 Javascript
jQuery动态移除和添加背景图片的方法详解
Mar 07 Javascript
vue2.0 常用的 UI 库实例讲解
Dec 12 Javascript
Vue-cli中为单独页面设置背景色的实现方法
Feb 11 Javascript
Vuex中mutations与actions的区别详解
Mar 01 Javascript
为vue项目自动设置请求状态的配置方法
Jun 09 Javascript
bootstrap 日期控件 datepicker被弹出框dialog覆盖的解决办法
Jul 09 Javascript
基于vue+uniapp直播项目实现uni-app仿抖音/陌陌直播室功能
Nov 12 Javascript
微信小程序实现倒计时功能
Nov 19 Javascript
JS如何监听div的resize事件详解
Dec 03 Javascript
详解JS预解析原理
Jun 16 #Javascript
深入了解JS之作用域和闭包
Jun 16 #Javascript
JS数组及对象遍历方法代码汇总
Jun 16 #Javascript
浅谈Vue 函数式组件的使用技巧
Jun 16 #Javascript
原生JS实现天气预报
Jun 16 #Javascript
vue实现公告栏文字上下滚动效果的示例代码
Jun 16 #Javascript
原生JS实现无缝轮播图片
Jun 24 #Javascript
You might like
PHP中使用foreach和引用导致程序BUG的问题介绍
2012/09/05 PHP
如何使用PHP获取指定日期所在月的开始日期与结束日期
2013/08/01 PHP
php颜色转换函数hex-rgb(将十六进制格式转成十进制格式)
2013/09/23 PHP
php_pdo 预处理语句详解
2016/11/21 PHP
laravel框架上传图片实现实时预览功能
2019/10/14 PHP
PHP框架实现WebSocket在线聊天通讯系统
2019/11/21 PHP
PHP call_user_func和call_user_func_array函数的简单理解与应用分析
2019/11/25 PHP
巧妙破除网页右键禁用的十大绝招
2006/08/12 Javascript
读jQuery之三(构建选择器)
2011/06/11 Javascript
两种方法实现在HTML页面加载完毕后运行某个js
2014/06/16 Javascript
JS实现简单的二元方程计算器功能示例
2017/01/03 Javascript
js实现适配不同的屏幕大小
2017/04/10 Javascript
nodejs利用ajax实现网页无刷新上传图片实例代码
2017/06/06 NodeJs
基于Vue.js 2.0实现百度搜索框效果
2020/12/28 Javascript
微信小程序功能之全屏滚动效果的实现代码
2018/11/22 Javascript
js canvas画布实现高斯模糊效果
2018/11/27 Javascript
js变量声明var使用与不使用的区别详解
2019/01/21 Javascript
vue实现条件叠加搜索的解决方法
2019/05/28 Javascript
浅谈关于vue中scss公用的解决方案
2019/12/02 Javascript
js实现简单的贪吃蛇游戏
2020/04/23 Javascript
element-ui 弹窗组件封装的步骤
2021/01/22 Javascript
从局部变量和全局变量开始全面解析Python中变量的作用域
2016/06/16 Python
python实现随机调用一个浏览器打开网页
2018/04/21 Python
Flask框架Flask-Principal基本用法实例分析
2018/07/23 Python
python 实现分页显示从es中获取的数据方法
2018/12/26 Python
python判断自身是否正在运行的方法
2019/08/08 Python
解决Django后台ManyToManyField显示成Object的问题
2019/08/09 Python
python 实现任务管理清单案例
2020/04/25 Python
Python批量处理csv并保存过程解析
2020/05/16 Python
医学生求职自荐信
2013/10/25 职场文书
企业挂职心得体会
2014/09/10 职场文书
入党宣誓仪式主持词
2015/06/29 职场文书
国际贸易实训总结
2015/08/03 职场文书
小程序实现文字循环滚动动画
2021/06/14 Javascript
Python操作CSV格式文件的方法大全
2021/07/15 Python
windows11怎么查看wifi密码? win11查看wifi密码的技巧
2021/11/21 数码科技