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 相关文章推荐
jquery.boxy插件的iframe扩展代码
Jul 02 Javascript
JavaScript中使用构造函数实现继承的代码
Aug 12 Javascript
为jQuery增加join方法的实现代码
Nov 28 Javascript
jQuery异步获取json数据方法汇总
Dec 22 Javascript
基于jQuery插件实现环形图标菜单旋转切换特效
May 15 Javascript
jQuery.Callbacks()回调函数队列用法详解
Jun 14 Javascript
js+css3制作时钟特效
Oct 16 Javascript
全面解析Node.js 8 重要功能和修复
Jun 02 Javascript
vue单页缓存方案分析及实现
Sep 25 Javascript
H5+C3+JS实现五子棋游戏(AI篇)
May 28 Javascript
微信上传视频文件提示(推荐)
Nov 22 Javascript
JavaScript手写数组的常用函数总结
Nov 22 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遍历数组的方法汇总分析
2013/06/08 PHP
PHP中使用imagick生成PSD文件缩略图教程
2015/01/26 PHP
[原创]php获取数组中键值最大数组项的索引值
2015/03/17 PHP
PHP实现的限制IP投票程序IP来源分析
2016/05/04 PHP
今天你说520了吗?不仅有php表白书还有java表白神器
2016/05/20 PHP
PHP操作MongoDB实现增删改查功能【附php7操作MongoDB方法】
2018/04/24 PHP
PHP实现创建一个RPC服务操作示例
2020/02/23 PHP
php设计模式之原型模式分析【星际争霸游戏案例】
2020/03/23 PHP
php设计模式之适配器模式实例分析【星际争霸游戏案例】
2020/04/07 PHP
asp.net+js 实现无刷新上传解析csv文件的代码
2010/05/17 Javascript
Asp.net下使用Jquery Ajax传送和接收DataTable的代码
2010/09/12 Javascript
ie下jquery.getJSON的缓存问题的处理方法
2013/03/29 Javascript
使用JavaScript的ActiveXObject对象检测应用程序是否安装的方法
2014/04/15 Javascript
window.open()详解及浏览器兼容性问题示例探讨
2014/05/29 Javascript
在myeclipse中如何加入jquery代码提示功能
2014/06/03 Javascript
jquery中radio checked问题
2015/03/16 Javascript
浅谈javascript中基本包装类型
2015/06/03 Javascript
this,this,再次讨论javascript中的this,超全面(经典)
2016/01/05 Javascript
基于JavaScript实现表单密码的隐藏和显示出来
2016/03/02 Javascript
canvas时钟效果
2017/02/16 Javascript
jQuery常见面试题之DOM操作详析
2017/07/05 jQuery
js使用原型对象(prototype)需要注意的地方
2017/08/28 Javascript
vue-router路由懒加载和权限控制详解
2017/12/13 Javascript
微信小程序实现判断是分享到群还是个人功能示例
2019/05/03 Javascript
Vue 解决路由过渡动画抖动问题(实例详解)
2020/01/05 Javascript
ant design vue中日期选择框混合时间选择器的用法说明
2020/10/27 Javascript
Python中的作用域规则详解
2015/01/30 Python
Python利用operator模块实现对象的多级排序详解
2017/05/09 Python
Python 等分切分数据及规则命名的实例代码
2019/08/16 Python
matplotlib基础绘图命令之errorbar的使用
2020/08/13 Python
彪马日本官网:PUMA日本
2019/01/31 全球购物
laravel使用redis队列实例讲解
2021/03/23 PHP
卫校中专生个人自我评价
2013/09/19 职场文书
租赁意向书范本
2014/04/01 职场文书
供货协议书范本
2014/04/22 职场文书
2016年教师党员承诺书范文
2016/03/24 职场文书