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 相关文章推荐
js实现简单的星级选择器提交效果适用于评论等
Oct 18 Javascript
javascript中判断json的方法总结
Aug 27 Javascript
jquery实现网页的页面平滑滚动效果代码
Nov 02 Javascript
关于网页中的无缝滚动的js代码
Jun 09 Javascript
jQuery Tags Input Plugin(添加/删除标签插件)详解
Jun 20 Javascript
总结Javascript中数组各种去重的方法
Oct 04 Javascript
详解Vue 实例中的生命周期钩子
Mar 21 Javascript
微信小程序点击控件修改样式实例详解
Jul 07 Javascript
详解vue服务端渲染浏览器端缓存(keep-alive)
Oct 12 Javascript
vue 自动化路由实现代码
Sep 03 Javascript
vue-cli打包后本地运行dist文件中的index.html操作
Aug 12 Javascript
Jquery+javascript实现支付网页数字键盘
Dec 21 jQuery
详解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加密解密函数Authcode()修复版代码
2015/04/05 PHP
thinkphp5框架结合mysql实现微信登录和自定义分享链接与图文功能示例
2019/08/13 PHP
JXTree对象,读取外部xml文件数据,生成树的函数
2007/04/02 Javascript
jquery select选中的一个小问题
2009/10/11 Javascript
Highcharts 非常实用的Javascript统计图demo示例
2013/07/03 Javascript
js实现文章文字大小字号功能完整实例
2014/11/01 Javascript
javascript中的正则表达式使用指南
2015/03/01 Javascript
基于JavaScript实现动态创建表格和增加表格行数
2015/12/20 Javascript
一些实用性较高的js方法
2016/04/19 Javascript
关于微信中a链接无法跳转问题
2016/08/02 Javascript
微信小程序组件 contact-button(客服会话按钮)详解及实例代码
2017/01/10 Javascript
nodejs连接mysql数据库简单封装示例-mysql模块
2017/04/10 NodeJs
捕获未处理的Promise错误方法
2017/10/13 Javascript
使用express搭建一个简单的查询服务器的方法
2018/02/09 Javascript
angularjs 的数据绑定实现原理
2018/07/02 Javascript
JS使用Date对象实时显示当前系统时间简单示例
2018/08/23 Javascript
jQuery+PHP+Ajax实现动态数字统计展示功能
2019/12/25 jQuery
vue更改数组中的值实例代码详解
2020/02/07 Javascript
JQuery表单元素取值赋值方法总结
2020/05/12 jQuery
JavaScript DOM常用操作代码汇总
2020/07/03 Javascript
[38:51]2014 DOTA2国际邀请赛中国区预选赛 Orenda VS LGD-CDEC
2014/05/22 DOTA
[02:07]2017国际邀请赛中国区预选赛直邀战队前瞻
2017/06/23 DOTA
Python动态导入模块的方法实例分析
2018/06/28 Python
python提取包含关键字的整行数据方法
2018/12/11 Python
Python如何实现强制数据类型转换
2019/11/22 Python
Python如何使用27行代码绘制星星图
2020/07/20 Python
html5声频audio和视频video等新特性详细说明
2012/12/26 HTML / CSS
《一个小村庄的故事》教学反思
2014/04/13 职场文书
运动会方队口号
2014/06/07 职场文书
幼儿园六一亲子活动方案
2014/08/26 职场文书
副乡长民主生活会个人对照检查材料思想汇报
2014/10/01 职场文书
专题组织生活会发言材料
2014/10/17 职场文书
2015年学校教研室主任工作总结
2015/07/20 职场文书
活动宣传稿范文
2015/07/23 职场文书
2016教师廉洁从教心得体会
2016/01/13 职场文书
《揠苗助长》教学反思
2016/02/20 职场文书