vue 中.sync修饰符的使用方法

本文介绍了Vue.js中的一种简化父子组件通信的方法——.sync修饰符。通常,子组件通过$emit触发事件来更新父组件的值,而父组件通过监听事件并处理回调来接收。然而,.sync修饰符提供了一种更简洁的语法,允许直接在模板中实现双向绑定。尽管如此,.sync并不适用于所有场景,如input等受控组件。在使用.sync时,需要注意其可能带来的不可控性问题。
摘要由CSDN通过智能技术生成

最近在项目中看到有些地方用了.sync修饰符,所以进一步了解一下,并记录。
vue官网.sync修饰符介绍:点击查看
一般情况下,子组件向父组件传值并改变值都需要使用回调方法,但有更简洁的写法。
如下为简易案例:
常见的回调函数写法

//	子组件代码:

<template>
	<div>
		<button @click="setNum">点击传值</button>
	</div>
</template>
<script>
	data() {
   		return {
   			num:20
   		}
   	}
   	methods: {
		setNum(){
			this.$emit('getNum',this.num)
		}
	}
</script>
//	父组件代码:

<template>
	<div>
		<Children @getNum="getNum"></Children>
		<text>{{number}}</text>	
	</div>
</template>
<script>
	data() {
   		return {
   			number:0
   		}
   	}
   	methods: {
		getNum(val){
			this.number = val
		}
	}
</script>

点击前后如下
在这里插入图片描述在这里插入图片描述
使用.sync修饰符写法

//	子组件代码:

<template>
	<div>
		<button @click="setNum">点击传值</button>
	</div>
</template>
<script>
	data() {
   		return {
   			num:20
   		}
   	}
   	methods: {
		setNum(){
			this.$emit('updata:sum',this.num)
		}
	}
</script>
//	父组件代码:

<template>
	<div>
		<Children :sum.sync="number"></Children>
		<text>{{number}}</text>	
	</div>
</template>
<script>
	data() {
   		return {
   			number:0
   		}
   	}
   	methods: {
	}
</script>

点击效果同上。
回调函数写法核心代码:

//	子组件
this.$emit('getNum',this.num)

//	父组件
<Children @getNum="getNum"></Children>
getNum(val){
	this.number = val
}

.sync修饰符写法核心代码:

//	子组件
this.$emit('updata:sum',this.num)

//	父组件
<Children :sum.sync="number"></Children>

虽然.sync更加简洁,但使用其他组件时是不受控的,如:input,radio,checkbox等
以input为例:

//	子组件

<input type="text" v-model="text" />
<button @click="sumbit">提交</button>

sumbit(){
    this.$emit('updata:text',this.text)
    console.log(this.text)	//这里可以正常打印
}
//	父组件

<Children :text.sync="text"></Children>
<text>{{text}}</text>

console.log(this.text)//这里打印为空
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue ,.sync 是一个语法糖,它能够简化父子组件之间的数据传递。.sync 修饰符实际上是一个双向绑定的简写形式,它会自动创建一个名为 update:propName 的自定义事件,并且在父组件监听这个事件,然后更新子组件的数据。 例如,在父组件使用子组件时,可以通过 v-bind.sync 修饰符将父组件的数据与子组件的数据绑定在一起: ``` <template> <ChildComponent :message.sync="messageFromParent"></ChildComponent> </template> ``` 这里的 .sync 修饰符会自动将子组件的 message 属性与父组件的 messageFromParent 属性进行双向绑定,并且在父组件监听名为 update:message 的自定义事件,以更新父组件的数据。 ``` <template> <ChildComponent :message.sync="messageFromParent"></ChildComponent> <button @click="updateMessage">Update Message</button> </template> <script> export default { data() { return { messageFromParent: 'Hello World' } }, methods: { updateMessage() { this.messageFromParent = 'Hello Vue' } } } </script> ``` 在子组件,可以通过 $emit() 方法触发 update:message 事件,以更新父组件的数据。 ``` <template> <div> <input type="text" v-model="message"> <button @click="$emit('update:message', message)">Update Message</button> </div> </template> <script> export default { props: { message: { type: String } } } </script> ``` 这样,父组件和子组件之间就可以通过 .sync 修饰符实现双向数据绑定了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值