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 学习笔记(十三)Dom创建表格
Jan 21 Javascript
初窥JQuery(二)事件机制(2)
Dec 06 Javascript
JavaScript和jQuery获取input框的绝对位置实现方法
Oct 13 Javascript
AngularJS辅助库browserTrigger用法示例
Nov 03 Javascript
JS数组去重(4种方法)
Mar 27 Javascript
使用vue实现grid-layout功能实例代码
Jan 05 Javascript
layui结合form,table的全选、反选v1.0示例讲解
Aug 15 Javascript
详解微信小程序文件下载--视频和图片
Apr 24 Javascript
Vue使用zTree插件封装树组件操作示例
Apr 25 Javascript
Layui多选只有最后一个值的解决方法
Sep 02 Javascript
vue本地打开build后生成的dist文件夹index.html问题
Sep 04 Javascript
Vue的v-model的几种修饰符.lazy,.number和.trim的用法说明
Aug 05 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
虹吸壶是谁发明的?煮出来的咖啡好喝吗
2021/03/04 冲泡冲煮
PHP将字符分解为多个字符串的方法
2014/11/22 PHP
php双层循环(九九乘法表)
2017/10/23 PHP
laravel解决迁移文件一次删除创建字段报错的问题
2019/10/24 PHP
PHP Pipeline 实现中间件的示例代码
2020/04/26 PHP
通过PHP实现用户注册后邮箱验证激活
2020/11/10 PHP
让你的网站可编辑的实现js代码
2009/10/19 Javascript
jquery固定底网站底部菜单效果
2013/08/13 Javascript
JavaScript DOM基础
2015/04/13 Javascript
js调出上下文菜单的实例
2015/12/17 Javascript
第三章之Bootstrap 表格与按钮功能
2016/04/25 Javascript
详解axios 全攻略之基本介绍与使用(GET 与 POST)
2017/09/15 Javascript
vue-cli3搭建项目的详细步骤
2018/12/05 Javascript
element-ui表格合并span-method的实现方法
2019/05/21 Javascript
解决layui富文本编辑器图片上传无法回显的问题
2019/09/18 Javascript
Vue实例的对象参数options的几个常用选项详解
2019/11/08 Javascript
在Python中操作字符串之replace()方法的使用
2015/05/19 Python
Python中使用不同编码读写txt文件详解
2015/05/28 Python
python抓取网页中图片并保存到本地
2015/12/01 Python
Python cookbook(数据结构与算法)找到最大或最小的N个元素实现方法示例
2018/02/13 Python
python 接口返回的json字符串实例
2018/03/27 Python
浅谈Django中的数据库模型类-models.py(一对一的关系)
2018/05/30 Python
python之消除前缀重命名的方法
2018/10/21 Python
Python饼状图的绘制实例
2019/01/15 Python
Python OpenCV之图片缩放的实现(cv2.resize)
2019/06/28 Python
Python3 shelve对象持久存储原理详解
2020/03/23 Python
python爬虫数据保存到mongoDB的实例方法
2020/07/28 Python
HTML5拖拉上传文件的简单实例
2017/01/11 HTML / CSS
选购世界上最好的美妆品:Cult Beauty
2017/11/03 全球购物
SKECHERS官方旗舰店:美国舒适运动休闲品牌
2017/12/22 全球购物
将一个文本文件的内容按倒序打印出来
2015/01/05 面试题
工程预算与管理应届生求职信
2013/10/06 职场文书
创意广告词
2014/03/17 职场文书
财务会计专业自荐书
2014/06/30 职场文书
学生无故旷课检讨书
2014/09/20 职场文书
Go语言编译原理之源码调试
2022/08/05 Golang