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浮动DIV提示信息并自动隐藏的代码
Aug 29 Javascript
详解JavaScript函数绑定
Aug 18 Javascript
Javascript前端UI框架Kit使用指南之kitjs事件管理
Nov 28 Javascript
详解JavaScript中setSeconds()方法的使用
Jun 11 Javascript
JS实现table表格数据排序功能(可支持动态数据+分页效果)
May 26 Javascript
javascript 四十条常用技巧大全
Sep 09 Javascript
bootstrap table分页模板和获取表中的ID方法
Jan 10 Javascript
Bootstrap3 多个模态对话框无法显示的解决方案
Feb 23 Javascript
Angular2使用Angular CLI快速搭建工程(一)
May 21 Javascript
关于vue-router的beforeEach无限循环的问题解决
Sep 09 Javascript
通过JavaScript下载文件到本地的方法(单文件)
Mar 17 Javascript
JavaScript实现滑动门效果
Jan 18 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中使用Oracle数据库(3)
2006/10/09 PHP
PHP5.0 TIDY_PARSE_FILE缓冲区溢出漏洞的解决方案
2018/10/14 PHP
Laravel 框架控制器 Controller原理与用法实例分析
2020/04/14 PHP
jquery淡化版banner异步图片文字效果切换图片特效
2014/04/08 Javascript
仿百度联盟对联广告实现代码
2014/08/30 Javascript
javascript实现网页字符定位的方法
2015/07/14 Javascript
javascript html5 canvas实现可拖动省份的中国地图
2016/03/11 Javascript
使用jquery.form.js实现图片上传的方法
2016/05/05 Javascript
Node.js的环境安装配置(使用nvm方式)
2016/10/11 Javascript
移动端点击态处理的三种实现方式
2017/01/12 Javascript
React-Native 组件之 Modal的使用详解
2017/08/08 Javascript
Mongoose实现虚拟字段查询的方法详解
2017/08/15 Javascript
bootstrap时间插件daterangepicker使用详解
2017/10/19 Javascript
javascript函数的节流[throttle]与防抖[debounce]
2017/11/15 Javascript
nuxt 自定义 auth 中间件实现令牌的持久化操作
2020/11/05 Javascript
详解阿里Node.js技术文档之process模块学习指南
2021/01/04 Javascript
[52:36]VGJ.S vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
Python入门之三角函数atan2()函数详解
2017/11/08 Python
Python第三方Window模块文件的几种安装方法
2018/11/22 Python
Python实现随机取一个矩阵数组的某几行
2019/11/26 Python
在Mac中PyCharm配置python Anaconda环境过程图解
2020/03/11 Python
Python3爬虫带上cookie的实例代码
2020/07/28 Python
Python pymysql模块安装并操作过程解析
2020/10/13 Python
HTML5、Select下拉框右边加图标的实现代码(增进用户体验)
2017/10/16 HTML / CSS
美国最大的珠宝商之一:Littman Jewelers
2016/11/13 全球购物
英国领先的野生鸟类食品供应商:GardenBird
2018/08/09 全球购物
彪马日本官网:PUMA日本
2019/01/31 全球购物
澳大利亚头发和美容产品购物网站:OZ Hair & Beauty
2020/03/27 全球购物
高中运动会入场词
2014/02/14 职场文书
小学绿色学校申报材料
2014/08/23 职场文书
党员干部形式主义个人整改措施
2014/09/17 职场文书
个人学习群众路线心得体会
2014/11/05 职场文书
超市食品安全承诺书
2015/04/29 职场文书
社区禁毒宣传活动总结
2015/05/07 职场文书
卫生保健工作总结2015
2015/05/18 职场文书
红色故事汇观后感
2015/06/18 职场文书