vue element dialog 弹窗单独组件

大家想要单独弹窗组件,我猜测应该是对表单的提交,这里演示表单弹窗,本人后端开发,有不对的地方勿喷

一、创建单独组件TestDialog.vue,这算是个子组件,代码element官网有

<template>
  <div>
	<!-- 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>
  </div>
</template>
<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 弄'
        }],
        dialogFormVisible: false, //这里是控制弹窗是否显示的,可以看下哪里引用到了
        form: {
          name: '',
          region: '',
          date1: '',
          date2: '',
          delivery: false,
          type: [],
          resource: '',
          desc: ''
        },
        formLabelWidth: '120px'
      };
    }
  };
</script>

二、在自己的父组件引入弹窗组件,也就是想要引用dialog弹窗的组件

<template>
  <div>
  	<el-button size="mini" @click="handleEdit()">编辑</el-button>
  	<TestDialog ref="TestDialog"></TestDialog>  <!--引入弹窗标签-->
  </div>
</template>
<script>
import TestDialog from "@/components/dialog/TestDialog"; //导入弹窗组件
export default {
  components: {
    TestDialog //注册弹窗组件
  },
  methods: {
    handleEdit() {
      this.$refs.TestDialog.dialogFormVisible = true; //用于改变弹窗子组件是否显示的属性
    },
}
</script>

这就完成了一个弹窗单独组件的实现,至于父子组件传参可自行百度$refs和prop

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值