【Vuejs】802- 如何区别 Vue2 和 Vue3 ?
作者:王立发
https://zhuanlan.zhihu.com/p/267040951
Vue 3 的 Template 支持多个根标签,Vue 2 不支持 Vue 3 有 createApp(),而 Vue 2 的是 new Vue()
createApp(组件),new Vue({template, render})v-model代替以前的v-model和.sync
vue3中v-model的用法
要求:
3.1. props属性名任意,假设为x
3.2. 事件名必须为"update:x"
效果:
"y" @update:value="y=$event"/>
vue2中的写法
"y"/>
vue3中的写法
"y"/>
4. context.emit
新增context.emit,与this.$emit(vue3中只能在methods里使用)作用相同
context.emit用法
import {SetupContext } from 'vue'
setup(props: Prop, context: SetupContext) {
const toggle = () => {
context.emit('input', !props.value)
}
return {toggle}
}
5. Vue3中的属性绑定
默认所有属性都绑定到根元素
使用inheritAttrs: false可以取消默认绑定
使用attrs或者context.attrs获取所有属性
使用v-bing="$attrs"批量绑定属性
使用 const {size, level, ...rest} = context.attrs 将属性分开
5.1 使用场景
在vue2中我们在父组件绑定click事件,子组件必须内部触发click,而vue3中在父组件绑定子组件的根元素上也会跟着绑定
ButtonDemo.vue
<Button @click="onClick" @focus="onClick" size="small">你好Button>
</div>
setup() {
const onClick = () => {
console.log("aaa")
}
return {onClick}
},
Button.vue
<div>
<button>
<slot/>
button>
div>
</template>
上面的代码Button的click事件会在根元素div上绑定,如果我们要指定click的区域为button元素的话我们就需要使用inheritAttrs
Button.vue
<div>
<button v-bind="$attrs">
<slot/>
button>
div>
</template>