vue3和vue2 v-model 和sync语法糖区别

简介: 1.最近在搞v3的时候那些和v2典型的区别组合式API什么的都没啥大问题,但是遇到了父子组件通信的一些简洁写法的区别,记录如下

1.前言


1.最近在搞v3的时候那些和v2典型的区别组合式API什么的都没啥大问题,但是遇到了父子组件通信的一些简洁写法的区别,记录如下


2.先直接看下 v3咋写的


1.子组件的写法和v2是一样的

2.update事件后面跟上传递的属性名

3.第二个参数是 传的值


<template>
    <div>
        <button @click="$emit('update:num',num+1)">子组件修改:{{num}}</button>
    </div>
</template>
<script>
    export default {
        props:["num"]
    }
</script>


1.父组件使用方式和以前不一样了 文末有v2的用法自行对比

2.这必须使用 v-model指令 冒号: 跟上属性的名字

3.后面赋值还是一样的

4.需要注意的是这种写法 在vscode里面语法检查会报错,这个不用管,因为这块的语法ESlint没有更新,但是不会影响运行的


<h1>父组件数据: {{num}}</h1>
  <msg-skill v-model:num="num"></msg-skill>



3.接着回顾下v2父子组件的2种简洁写法


3.1 v-model

父组件内使用子组件


<btn v-model="num"></btn>

子组件


Vue.component("btn",{
        props:["value"],
        template:`
            <div>
                <button @click="$emit('input',value+1)">按钮 {{value}}</button>   
            </div>
        `
    })

v-model 相当于

1.父组件绑定input事件

2.value绑定输入框的值


<btn :value="value " @input="value = $event.target.value "></btn>

3.所以 可以通过父组件使用v-model指令 代替绑定值和事件

4.子组件直接通过 $emit()触发input事件


3.2 sync语法糖

父组件 属性.sync=变量


<btn2 :num.sync="num" ></btn2>


子组件


Vue.component("btn2",{
        props:["num"],
        template:`
            <div>
                <button @click="$emit('update:num',num+1)">按钮 {{num}}</button>   
            </div>
        `
    })

子组件通过 $emit()触发update事件

事件后面跟上 传递的属性'update:num'

后续参数是 需要传递的值




相关文章
|
2月前
|
JavaScript 前端开发 开发者
Vue v-for 进阶指南:in 与 of 的区别及应用场景 | 笔记
Vue.js 中的 v-for 是强大的遍历指令,但其中的 in 和 of 关键字往往被开发者忽视。尽管它们的用法相似,但适用的场景和数据结构却各有不同。本文将详细探讨 v-for 中 in 和 of 的区别、适用场景以及在实际开发中的最佳使用时机。通过理解它们的差异,你将能够编写更加高效、简洁的 Vue.js 代码,灵活应对各种数据结构的遍历需求。
90 6
|
2月前
|
缓存 JavaScript
Vue 中 computed 与 method 的区别
【10月更文挑战第15天】computed 和 method 是 Vue 中两个重要的选项,它们在功能和特点上存在着明显的区别。理解并合理运用它们的区别,可以帮助我们构建更高效、更具可维护性的 Vue 应用。在实际开发中,要根据具体情况灵活选择使用,以满足不同的需求。
25 2
|
2月前
|
JavaScript 前端开发 算法
对比一下Vue2 和 Vue3?—— 8个方面给你答案
本文介绍了 Vue 和 React 的起源、核心思想、表现形式、API 差异、社区差异、升级方向、响应式原理、Diff 算法、事件机制,并进行了总结。Vue 以其渐进式框架设计和简洁性著称,而 React 则强调单向数据流和灵活性。两者均支持组件化开发和虚拟 DOM,适用于不同的开发场景。
27 0
对比一下Vue2 和 Vue3?—— 8个方面给你答案
|
2月前
|
缓存 JavaScript 前端开发
对比一下Vue2和Vue3?
本文首发于微信公众号“前端徐徐”,详细对比了 Vue 2 和 Vue 3 在原理、生命周期、性能、编码方式、API、Diff 算法、打包构建、TS 支持等八个方面的差异,帮助读者全面了解两者的不同之处。
201 0
对比一下Vue2和Vue3?
|
2月前
|
JavaScript 前端开发 Java
vue2知识点:Vue封装的过度与动画
vue2知识点:Vue封装的过度与动画
15 0
|
2月前
|
缓存 JavaScript Serverless
vue中computed计算属性、watch侦听器、methods方法的区别以及用法
vue中computed计算属性、watch侦听器、methods方法的区别以及用法
118 0
|
2月前
|
JavaScript API 开发工具
vue2和vue3版本区别
【10月更文挑战第4天】
|
12天前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
28 1
vue学习第四章
|
12天前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
26 1
vue学习第九章(v-model)
|
12天前
|
JavaScript 前端开发 开发者
vue学习第十章(组件开发)
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文深入讲解Vue组件的基本使用、全局与局部组件、父子组件通信及数据传递等内容,适合前端开发者学习参考。持续更新中,期待您的关注!🎉🎉🎉
27 1
vue学习第十章(组件开发)