您现在的位置是:群英 > 开发技术 > web开发
v-model与.sync修饰符的差异有哪些
Admin发表于 2022-11-12 17:53:34512 次浏览
这篇文章给大家分享的是“v-model与.sync修饰符的差异有哪些”,文中的讲解内容简单清晰,对大家学习和理解有一定的参考价值和帮助,有这方面学习需要的朋友,接下来就跟随小编一起学习一下“v-model与.sync修饰符的差异有哪些”吧。



在日常开发的过程中,v-model指令是经常用到的,一般来说v-model指令在表单及元素上创建双向数据绑定,但v-model本质上是语法糖。提到语法糖这里就不得不提到另一个与v-model有相似功能的双向绑定语法糖了,那就是.sync修饰符。在这里对两者进行一下总结:

一、v-model

1. 作用

相信过使用过vue框架的朋友对这个指令不会感到陌生,v-model是用来进行<input><textarea><select>元素上数据的双向绑定的。(学习视频分享:vue视频教程)

例如:

<template>
    <div >
        <input v-model="value" type="text"/>    //这里的v-model里面的value可以直接获取到用户的输入值
    </div>
</template>

<script>

export default {
    components: {},
    data() {
        return {
            value:"",    //这里定义的value变量可以直接将上面获取到的值进行操作
        };
      }, 
    }
</script>
<style  scoped>

</style>
登录后复制

当我们在input框里输入了某个值的时候,下面data里的value就可以直接后去到我们输入的值,而不需要操作dom元素进行获取。

1. 本质

v-model本质上来说是一个语法糖,我们习惯性的写法是这样的:

 <input v-model="value" type="text"/>
登录后复制

但是实际上完整的写法是这样的:

<input :value="value" @input="value=$event.target.value" type="text" />
登录后复制

通过对比语法糖和原始写法可以得出: 再给<input/>元素添加v-model属性时,默认会把value作为元素的属性,然后把input事件作为实时传递value的触发事件。

注意:不是所有能进行双向数据绑定的元素都是input事件!

3、特殊用法

一般情况下,我们使用v-model主要是用于数据的双向绑定,可以十分方便的获取到用户输入的值,但在某些特殊情况下,我们也可以将v-model用于父子组件之间数据的双向绑定。

<template>
    <div class="father">
        <Son v-model="str"/>
    </div>
</template>

<script>

import Son from '@/components/Son.vue';    //引入子组件

export default {
    components: {Son},
    data() {
        return {
            str:"father"
        };
      },
    }
</script>
登录后复制

这里定义了一个father组件和son组件,并且将son组件引入到father组件中,给son组件绑定了v-model进行了传值。此时我们需要在son组件中接收并使用这个值:

<template>
    <div class="son">
        我是在son组件里接收到的值:{{value}}
    </div>
</template>
<script>
export default {
    components: {},
    props:{
        value:{
            type:String,
        },
      },
    }
</script>
登录后复制

注意:这里接受的值必须是value,写成其他名字将会报错!

父组件向子组件传值,子组件中是不能直接修修改数据的,直接修改的话就会报错

当我们需要修改这个值时,就需要再将其传入到父组件中修改。

这就需要在父组件中的子组件上定义一个自定义事件,通过子组件$emit('自定义事件名称','值')的方法将值传入父组件。

但是在这里我们不能使用自定义事件,因为我们用的是v-model传值,所以我们只能使用input事件进行修改。

子组件中使用$emit()方法.调用父组件中的事件,并且进行传值

<template>
    <div class="son">
        我是在son组件里接收到的值:{{value}}
        <button @click="handleClick">click</button>
    </div>
</template>

<script>
export default {
    components: {},
    data() {
        return {
            str:'son'
        };
    },
    props:{
        value:{
            type:String,
        },
    },
    methods: {
        handleClick(){
            this.$emit('input',this.str)
        }
    },
    }
</script>
登录后复制

这样就完成父子组件之间的数据双向绑定效果

二、.sync修饰符

1、作用

.sync修饰符可以实现父子组件之间的双向绑定,并且可以实现子组件同步修改父组件的值,相比较与v-model来说,sync修饰符就简单很多了:

2、本质

    //正常父传子
    <Son :a="num" />
    
    //加上sync之后的父传子
    <Son :a.sync="num" />
    
    //它等价于
    <Son :a="num" @update:a="val=>a=val" />
    
    //相当于多了一个事件监听,事件名是update:a,
    //回调函数中,会把接收到的值赋值给属性绑定的数据项中。
登录后复制

这里面的传值与接收和正常的父组件向子组件传值没有区别,唯一的区别在于子组件往回传值的时候$emit所调用的事件名必须是update:属性名,事件名写错不会报错,但那时也不会有任何改变,这点需要注意。

总结

v-model与.sync: 相同点:都是语法糖,都可以实现父子组件中的数据通信。

不同点:格式不同,v-model="num" :num.sync="num"

v-model:@input+value :num.sync:@update:num

还有就是,v-model只能使用一次,.sync可以使用多个。


以上就是关于“v-model与.sync修饰符的差异有哪些”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注群英网络,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: v-model与.sync
相关信息推荐
2022-08-01 17:52:15 
摘要:php数组逆向排序是“array_reverse()”函数。array_reverse()函数可以翻转数组元素的顺序,以相反的元素顺序返回数组,语法“array_reverse($array,$preserve)”;该函数的第二个参数“$preserve”可省略,用于规定是否保留原数组的键名,如果值设置为true,则键名保持不变,否则键名将丢失(键名重新从0开始且以1递增)。
2022-02-09 17:57:13 
摘要:PHP中判断当天时间段的思路和方法是什么?我们想要知道时间是不是当天的时间,那么首先我们需要先获取当前的日期,然后再进行条件判断就可以了,这篇使用的是if判断,下面我们来详细的看看,怎样实现。
2022-05-09 16:13:08 
摘要:html实现内容超出自动隐藏的方法是,给文本内容添加overflow属性,并且设置属性值为hidden即可,例如【div{overflow: hidden;}】。
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部