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 相关文章推荐
解决FireFox下[使用event很麻烦]的问题
Nov 26 Javascript
javascript上传图片前预览图片兼容大多数浏览器
Oct 25 Javascript
浅谈JavaScript的事件
Feb 27 Javascript
js实现带关闭按钮始终显示在网页最底部工具条的方法
Mar 02 Javascript
JS转换HTML转义符的方法
Aug 24 Javascript
js+css3制作时钟特效
Oct 16 Javascript
JS简单实现数组去重的方法示例
Mar 27 Javascript
JS中的JSON对象的定义和取值实现代码
May 09 Javascript
微信小程序--特定区域滚动到顶部时固定的方法
Apr 28 Javascript
原生js实现无缝轮播图
Jan 11 Javascript
原生js实现分页效果
Sep 23 Javascript
如何用JS实现网页瀑布流布局
Apr 24 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 注释规范
2012/03/29 PHP
php流量统计功能的实现代码
2012/09/29 PHP
php连接与操作PostgreSQL数据库的方法
2014/12/25 PHP
轻轻松松学JS调试(不下载任何工具)
2010/04/14 Javascript
JQuery datepicker 使用方法
2011/05/20 Javascript
jQuery 淡入淡出 png图在ie8下有黑色边框的解决方法
2013/03/05 Javascript
IE6下拉框图层问题探讨及解决
2014/01/03 Javascript
NodeJS中利用Promise来封装异步函数
2015/02/25 NodeJs
js随机生成字母数字组合的字符串 随机动画数字
2015/09/02 Javascript
JS实现数字格式千分位相互转换方法
2016/08/01 Javascript
使用ionic切换页面卡顿的解决方法
2016/12/16 Javascript
JavaScript中数组常见操作技巧
2017/09/01 Javascript
JS实现遍历不规则多维数组的方法
2018/03/21 Javascript
微信小程序踩坑记录之解决tabBar.list[3].selectedIconPath大小超过40kb
2018/07/04 Javascript
详解如何模拟实现node中的Events模块(通俗易懂版)
2019/04/15 Javascript
vue实现菜单切换功能
2019/05/08 Javascript
浅谈关于vue中scss公用的解决方案
2019/12/02 Javascript
python生成IP段的方法
2015/07/07 Python
Python的re模块正则表达式操作
2016/05/25 Python
Python socket网络编程TCP/IP服务器与客户端通信
2017/01/05 Python
django将图片上传数据库后在前端显式的方法
2018/05/25 Python
终端命令查看TensorFlow版本号及路径的方法
2018/06/13 Python
python十进制和二进制的转换方法(含浮点数)
2018/07/07 Python
Python matplotlib学习笔记之坐标轴范围
2019/06/28 Python
利用python实现冒泡排序算法实例代码
2019/12/01 Python
python 循环数据赋值实例
2019/12/02 Python
Python ORM编程基础示例
2020/02/02 Python
Django values()和value_list()的使用
2020/03/31 Python
用Python制作mini翻译器的实现示例
2020/08/17 Python
html5 touch事件实现触屏页面上下滑动(一)
2016/03/10 HTML / CSS
详解基于canvas的视频遮罩插件
2018/01/04 HTML / CSS
自1926年以来就为冰岛保持温暖:66°North
2020/11/27 全球购物
祖国在我心中的演讲稿
2014/05/04 职场文书
2014年煤矿安全工作总结
2014/12/04 职场文书
资料员岗位职责
2015/02/10 职场文书
事业单位岗位说明书
2015/10/08 职场文书