弹框编辑/新增,双向监听绑定操作

背景:编辑、新增出现弹框,进行双向绑定,数据反填等操作。其中涉及父子组件传参、computed、watch相关知识。
步骤:

  1. 父组件
<!-- item  -->
<div @click="handleEditBtn(item)">编辑</div>
<!-- 引用子组件 -->
<childGrop
	open.sync="showChildBox"
	item="item"
></childGrop>
data() {
	return {
		item: {},
		showChildBox: false // 打开/显示子组件
	}
},
methods: {
	handleEditBtn(item) {
		this.showChildBox = true
		this.item = item
	}
}
  1. 子组件 childGroup
<el-dialog
	:visible.sync="visible"
>
	<div>{{item.collectType}}</div>
</el-dialog>
// 父传子 接收参数
props: {
    open: Boolean,
    item: Object
},
data() {
	return {
		cateType : ''
	}
},
computed() {
	visible: {
		// 获取变化后的参数
		get: functin(){
			// 方法一:打开即调取
			this.init()
			return this.open
		},
		// set监听变化
		set: functin(val){
			// 双向绑定
			this.$emit('update:open', val)
		}
	}
},
// 方法二:或者监听visible变化 获取反填数据  
//watch: {
   // visible(val) {
    //  if (val) {
    //    this.cateType = this.item.cateType 
    //  }
   // }
//  },
methods: {
	init() {
		if (!this.open) {
        	return
      	}
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值