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 相关文章推荐
javascript编程起步(第四课)
Feb 27 Javascript
发布一个基于javascript的动画类 Fx.js
Nov 05 Javascript
40个新鲜出炉的jQuery 插件和免费教程[上]
Jul 24 Javascript
关于锚点跳转及jQuery下相关操作与插件
Oct 01 Javascript
Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结
Nov 14 Javascript
JavaScript图片放大技术(放大镜)实现代码分享
Nov 14 Javascript
遍历json 对象的属性并且动态添加属性的实现
Dec 02 Javascript
JS实现图片放大缩小的方法
Feb 15 Javascript
微信小程序实战之轮播图(3)
Apr 17 Javascript
webpack使用 babel-loader 转换 ES6代码示例
Aug 21 Javascript
AngularJS 的$timeout服务示例代码
Sep 21 Javascript
JavaScript 与 TypeScript之间的联系
Nov 27 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从右向左/从左向右截取字符串的实现方法
2011/11/28 PHP
浅析PHP Socket技术
2013/08/02 PHP
ThinkPHP验证码使用简明教程
2014/03/05 PHP
PHP中模拟处理HTTP PUT请求的例子
2014/07/22 PHP
PHP生成数组再传给js的方法
2014/08/07 PHP
php通过pecl方式安装扩展的实例讲解
2018/02/02 PHP
禁止直接访问php文件代码分享
2020/05/05 PHP
phpstudy2020搭建站点的实现示例
2020/10/30 PHP
js自动下载文件到本地的实现代码
2013/04/28 Javascript
JavaScript 垃圾回收机制分析
2013/10/10 Javascript
JQuery EasyUI 数字格式化处理示例
2014/05/05 Javascript
浅谈JSON中stringify 函数、toJosn函数和parse函数
2015/01/26 Javascript
jQuery聚合函数实例
2015/05/21 Javascript
JQuery datepicker 用法详解
2015/12/25 Javascript
深入理解jquery自定义动画animate()
2016/05/24 Javascript
详解react-router如何实现按需加载
2017/06/15 Javascript
js HTML5 canvas绘制图片的方法
2017/09/08 Javascript
jQuery实现DIV响应鼠标滑过由下向上展开效果示例【测试可用】
2018/04/26 jQuery
Weex开发之地图篇的具体使用
2019/10/16 Javascript
Node.js+Vue脚手架环境搭建的方法步骤
2020/03/08 Javascript
vue过滤器实现日期格式化的案例分析
2020/07/02 Javascript
请求时token过期自动刷新token操作
2020/09/11 Javascript
[02:31]2018年度DOTA2最具人气选手-完美盛典
2018/12/16 DOTA
基于Python的身份证号码自动生成程序
2014/08/15 Python
分享Python字符串关键点
2015/12/13 Python
Python实现定时任务
2017/02/08 Python
Python集中化管理平台Ansible介绍与YAML简介
2019/06/12 Python
python 中pyqt5 树节点点击实现多窗口切换问题
2019/07/04 Python
会计实习期自我鉴定
2013/10/06 职场文书
网管求职信
2014/03/03 职场文书
商场促销活动策划方案
2014/08/18 职场文书
幼儿园见习报告
2014/10/30 职场文书
中班教师个人总结
2015/02/05 职场文书
教师理论学习心得体会
2016/01/21 职场文书
CSS的class与id常用的命名规则
2021/05/18 HTML / CSS
Spring JPA 增加字段执行异常问题及解决
2022/06/10 Java/Android