前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue实战案例(form表单动态添加组件)

Vue实战案例(form表单动态添加组件)

作者头像
用户4919348
发布2019-08-30 12:04:49
7.1K0
发布2019-08-30 12:04:49
举报
文章被收录于专栏:波波烤鸭波波烤鸭

  今天我们来给大家介绍下在Vue开发中我们经常会碰到的一种需求场景,就是在form中我们需要动态的增加组件模块,效果如下:

在这里插入图片描述
在这里插入图片描述

  这种效果实现其实就是对 v-for 指令的一种使用,组件不是必须的,只是为了将这部门的代码我们单独的拎出来,便于查看,好了,话不多说,我们来看下具体怎么来实现。

案例效果的实现

1.创建组件

  首先我们创建一个单独的组件,同时在 template 中定义我们的表单元素,此处使用的是 element UI 来实现效果。

在这里插入图片描述
在这里插入图片描述

2.import组件

  我们需要在父组件中引入创建的组件,并通过 v-for 来实现动态处理的效果,关键代码如下

在这里插入图片描述
在这里插入图片描述

使用组件

在这里插入图片描述
在这里插入图片描述

data 中定义 edus 数组.

在这里插入图片描述
在这里插入图片描述

3.实现添加功能

  要实现动态添加组件的功能,我们需要通过点击添加的按钮来增加数组 edus 中的元素,如下

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
let addEduView = function(){
    this.edus.push({})
}

如此即可实现动态添加的功能。

4.实现移除功能

  实现移除动态添加的组件,我们需要在组件中调用父组件中的方法。如下

父组件中定义移除的方法

代码语言:javascript
复制
let deleteEducation = function(index){
    if (index !== 0) {
        this.edus.splice(index, 1)
    }
}
在这里插入图片描述
在这里插入图片描述

子组件中回调

在这里插入图片描述
在这里插入图片描述

5.提交数据

  当我们要提交表单数据的时候,怎么将动态添加的组件中的数据一并提交给后台服务呢,步骤如下:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

提交数据的时候将 edus 数组中的数据和表单数据一块转换为 JSON 数据提交到后台。

在这里插入图片描述
在这里插入图片描述

6.清空组件

  最后操作完成需要将动态添加的组件处理掉怎么实现呢?其实效果很简单,我们只需要清空 edus 数组即可

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年08月30日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 案例效果的实现
    • 1.创建组件
      • 2.import组件
        • 3.实现添加功能
          • 4.实现移除功能
            • 5.提交数据
              • 6.清空组件
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档