前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >ElementUI Dialog 对话框,组件之间传值

ElementUI Dialog 对话框,组件之间传值

作者头像
py3study
发布于 2021-01-29 03:12:17
发布于 2021-01-29 03:12:17
4.8K02
代码可运行
举报
文章被收录于专栏:python3python3
运行总次数:2
代码可运行

一、概述

在保留当前页面状态的情况下,告知用户并承载相关操作。

二、自定义内容

Dialog 组件的内容可以是任意的,甚至可以是表格或表单,下面是应用了 Element Table 和 Form 组件的两个样例。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!-- Table -->
<el-button type="text" @click="dialogTableVisible = true">打开嵌套表格的 Dialog</el-button>

<el-dialog title="收货地址" :visible.sync="dialogTableVisible">
  <el-table :data="gridData">
    <el-table-column property="date" label="日期" width="150"></el-table-column>
    <el-table-column property="name" label="姓名" width="200"></el-table-column>
    <el-table-column property="address" label="地址"></el-table-column>
  </el-table>
</el-dialog>

<!-- Form -->
<el-button type="text" @click="dialogFormVisible = true">打开嵌套表单的 Dialog</el-button>

<el-dialog title="收货地址" :visible.sync="dialogFormVisible">
  <el-form :model="form">
    <el-form-item label="活动名称" :label-width="formLabelWidth">
      <el-input v-model="form.name" autocomplete="off"></el-input>
    </el-form-item>
    <el-form-item label="活动区域" :label-width="formLabelWidth">
      <el-select v-model="form.region" placeholder="请选择活动区域">
        <el-option label="区域一" value="shanghai"></el-option>
        <el-option label="区域二" value="beijing"></el-option>
      </el-select>
    </el-form-item>
  </el-form>
  <div slot="footer" class="dialog-footer">
    <el-button @click="dialogFormVisible = false">取 消</el-button>
    <el-button type="primary" @click="dialogFormVisible = false">确 定</el-button>
  </div>
</el-dialog>

<script>
  export default {
    data() {
      return {
        gridData: [{
          date: '2016-05-02',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        }, {
          date: '2016-05-04',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        }, {
          date: '2016-05-01',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        }, {
          date: '2016-05-03',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        }],
        dialogTableVisible: false,
        dialogFormVisible: false,
        form: {
          name: '',
          region: '',
          date1: '',
          date2: '',
          delivery: false,
          type: [],
          resource: '',
          desc: ''
        },
        formLabelWidth: '120px'
      };
    }
  };
</script>

点击打开嵌套表单的 Dialog,效果如下:

三、组件之间传值

在实际开发过程中,对于Dialog 对话框,会单独创建一个vue文件,进行处理。这样的话,维护页面比较方便。而不是在一个总的vue文件,涉及几千行代码。

下面使用一个小demo,结合Dialog 对话框,演示组件之间传值。

目标:

1. 父组件HelloWorld.vue,点击添加按钮,调用子组件company.vue,

2. 弹出Dialog 对话框。输入表单数据

3. 表单数据回传给父组件HelloWorld.vue

新建一个ElementUI项目,修改文件HelloWorld.vue,完整内容如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<template>
  <div class="hello">
    <el-row>
      <el-button type="primary" @click='add()'>添加</el-button>
    </el-row>
    <company ref="company" @children="parentCompany"></company>
  </div>

</template>

<script>
  // 导入组件company
  import company from "./company";

  export default {
    name: 'HelloWorld',
    // 注册组件
    components: {
      company,
    },
    data() {
      return {
        msg: 'Welcome to Your Vue.js App'
      }
    },
    methods: {
      add() {
        // 弹出对话框
        this.$refs.company.showDialog()
      },
      // 子组件传值给父组件-公司
      parentCompany(obj) {
        // 打印子组件传递的值
        console.log("parentCompany",obj)
      },
    },
  }
</script>

<style scoped>
</style>

在HelloWorld.vue同级目录下,新建文件company.vue

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<template>
  <el-dialog title="添加公司" :visible.sync="dialogFormVisible" width="500px">
    <el-form :model="form">
      <el-form-item label="公司名称" :label-width="formLabelWidth">
        <el-input v-model="form.name" autocomplete="off" style="width: 218px"></el-input>
      </el-form-item>
      <el-form-item label="公司区域" :label-width="formLabelWidth">
        <el-select v-model="form.region" placeholder="请选择活动区域">
          <el-option label="上海" value="shanghai"></el-option>
          <el-option label="北京" value="beijing"></el-option>
        </el-select>
      </el-form-item>
    </el-form>
    <div slot="footer" class="dialog-footer">
      <el-button @click="dialogFormVisible = false">取 消</el-button>
      <el-button type="primary" @click="setCompany()">确 定</el-button>
    </div>
  </el-dialog>
</template>

<script>
  export default {
    name: "company",
    data() {
      return {
        dialogFormVisible: false,
        form: {
          name: '',
          region: '',
        },
        formLabelWidth: '120px'
      }
    },
    methods: {
      showDialog() {
        this.dialogFormVisible = true
      },
      setCompany(){
        // $emit触发当前实例上的事件
        // 触发父组件的children事件,将this.form回传过去
        this.$emit('children',this.form)
        // 关闭对话框
        this.dialogFormVisible = false
      }
    },
  }
</script>

<style scoped>

</style>

访问首页,效果如下:

 点击添加按钮,弹出对话框,输入表单数据,点击确定

查看console,效果如下:

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/01/28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
我用Vue.js与ElementUI搭建了一个无限级联层级表格组件
今天,回老家了。第一件事就是回家把大屏安排上,写作的感觉太爽了,终于可以专心地写文章了。我们今天要做的项目是怎么样搭建一个无限级联层级表格组件,好了,多了不多说,赶快行动起来吧!
Vam的金豆之路
2021/12/01
6890
我用Vue.js与ElementUI搭建了一个无限级联层级表格组件
Element UI 快速入门指南
Element UI 是一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。它提供了一系列开箱即用的组件,帮助我们快速构建用户界面。本文将详细介绍如何快速入门 Element UI,并通过一些实例来展示其强大功能。
九转成圣
2024/06/09
2620
Element-UI 快速入门指南
在开始使用 Element-UI 之前,我们需要先安装它。可以使用 npm 或 yarn 进行安装。
IT_陈寒
2024/05/24
1.2K0
Element-UI 快速入门指南
ElementUI快速入门
在执行完npm run dev后发现浏览器自动打开了vue-admin-template登录页面,点击登录,此时模板页面就搭建好了。
Java架构师必看
2021/05/14
3.2K0
ElementUI快速入门
手把手教你实现一个Vue无限级联树形表格(增删改)
平时我们可能在做项目时,会遇到一个业务逻辑。实现一个无限级联树形表格,什么叫做无限级联树形表格呢?就是下图所展示的内容,有一个祖元素,然后下面可能有很多子孙元素,你可以实现添加、编辑、删除这样几个功能。
Vam的金豆之路
2021/12/01
5610
手把手教你实现一个Vue无限级联树形表格(增删改)
ElementUi中的Dialog对话框——弹出窗口与新增更新功能为例
进入ElementUi官网, 找到Dialog对话框,可以参考“嵌套表单的dialog”实现。 该步骤先实现弹出窗口的前端逻辑,并不会调用后台接口服务进行实际的业务操作。 BookList.vue
用户10196776
2022/11/22
4.4K0
ElementUi中的Dialog对话框——弹出窗口与新增更新功能为例
Vue.js与ElementUI搭建无限级联层级表格组件
今天,回老家了。第一件事就是回家把大屏安排上,写作的感觉太爽了,终于可以专心地写文章了。我们今天要做的项目是怎么样搭建一个无限级联层级表格组件,好了,多了不多说,赶快行动起来吧! 项目一览
马克社区
2022/05/09
1.3K0
手把手教你实现一个Vue无限级联树形表格(增删改)
平时我们可能在做项目时,会遇到一个业务逻辑。实现一个无限级联树形表格,什么叫做无限级联树形表格呢?就是下图所展示的内容,有一个祖元素,然后下面可能有很多子孙元素,你可以实现添加、编辑、删除这样几个功能。
马克社区
2022/05/11
1.5K0
vue2+element环境搭建实现table编辑效果
今天要简单说说vue加element项目的一个开发 本次用的技术栈是vue2+element2
爱学习的前端歌谣
2023/11/16
3380
vue2+element环境搭建实现table编辑效果
Vue使用Element实现增删改查+打包
在我们进行项目开发期间,避免不了使用各式各样的组件,Element是由饿了么公司前端团队开源。样式精美、组件齐全、易于上手。
憧憬博客
2020/07/20
2.2K0
Vue + Flask 小知识(四)
首先有一个简单的表单,一个必填的输入框,一个 textarea 类型输入框,还有两个多选的下拉框 页面效果如下:
周萝卜
2019/07/30
7230
Vue + Flask 小知识(四)
vue3+ts+element-plus项目总结2
最近,在写vue3 + ts 项目,项目中使用技术点总结2 , 推荐收藏,供开发时使用
用户9914333
2024/02/05
1800
vue3+ts+element-plus项目总结2
vue表格分页以及增删改查的实际应用
效果 1:表格以及分页 2:增加一条数据 3:删除一条数据 4:修改一条数据 5:查询一条数据 实例: <template> <div class="tab-container"> <d
王小婷
2021/03/17
1.9K0
D2 Crud 简单易用的表格组件
D2-Crud 是一套基于Vue.js 2.2.0+ 和 Element UI 2.0.0+ 的表格组件。 D2-Crud 将 Element 的功能进行了封装,并增加了表格的增删改查、数据校验、表格内编辑等常用的功能。大部分功能可由配置 json 实现,在实现并扩展了 Elememt 表格组件功能的同时,降低了开发难度,减少了代码量,大大简化了开发流程。
FairyEver
2019/07/26
1.9K0
猿实战13——实现你没听说过的前台类目
上几个章节,猿人君教会了你实现了属性/属性值和后台类目的绑定关系,今天,猿人君就带你来实现前台类目。
山旮旯的胖子
2020/09/23
6600
猿实战13——实现你没听说过的前台类目
【编程鹿】害 学element-ui 看这篇就够了
目前可以通过 unpkg.com/element-ui 获取到最新版本的资源,在页面上引入 js 和 css 文件即可开始使用。
鹿老师的Java笔记
2020/12/02
1.3K0
【编程鹿】害  学element-ui 看这篇就够了
Springboot快速开发-书本信息管理系统(项目源码)
generatorConfig.xml、jdbc.properties、application.yml这三个配置文件我就不展示了,有需要的下载我的资源包
天蝎座的程序媛
2022/11/18
6010
Springboot快速开发-书本信息管理系统(项目源码)
vue10CRUD+表单验证
目录 1. 准备工作 2. 弹出窗口 3. 新增更新功能  4. 删除功能 ​编辑  5. 表单验证  5. 接口文档 ---- 1. 准备工作 后台服务接口,对书本的增删改查操作 2. 弹出窗口 进入ElementUi官网, 找到Dialog对话框,可以参考“嵌套表单的dialog”实现。 该步骤先实现弹出窗口的前端逻辑,并不会调用后台接口服务进行实际的业务操作。 BookList.vue  <!-- 弹出窗口:增加和修改书本信息共用一个弹出窗口,需要根据用户的选择动态的设置弹出窗口的标题
天蝎座的程序媛
2022/11/18
2.5K0
vue10CRUD+表单验证
vue2.0 + element-ui 实战项目-点击按钮弹出form表单(五)
自从用饿了么框架重构项目以来,遇到 很多问题,我都有一一记录下来,现在特喜欢这个框架,说实话,如果你是用了vue这个技术栈的话,一定要用饿了么的pc端框架哦,遇到问题的时候在网上百度一下,就能找到解决方案,还有很多社区可以讨论,社区文档都比较成熟,很容易上手~~
王小婷
2020/11/12
5.5K0
vue+element的表格分页和前端搜索
1.前端后台管理会存在很多表格,表格数据过多就需要分页; 2.前端交互每次搜索如果都请求服务器会加大服务器的压力,所以在数据量不是很大的情况下可以一次性将数据返回,前端做检索 3.下面贴上一个demo
火狼1
2019/04/16
1.6K0
推荐阅读
相关推荐
我用Vue.js与ElementUI搭建了一个无限级联层级表格组件
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文