proxy 的方式实现数据代理,只会代理第一层数据 避免了vue2中对data的深层递归,提升了组件渲染性能。上例中,返回的state是一个 proxy 对象,默认只会对 data 进行代理 那么vue3是怎么实现深层数据劫持呢,例如我们要修改obj那么是怎么监听到obj的修改呢? 当我们要对深层对象obj进行修改时,会调用 state.data 的 get 方法,在 get 方法中会对 state.data 进行代理,劫持 state.data 中的属性, get 方法返回的不是 state.data 本身,而是被 proxy 代理过的对象,从而巧妙的实现了深层数据劫持,在用到该属性的时候一定会调用父级的 get 方法,这时候才会去劫持属性的 get 和 set 方法。
vue3 中用 setup 函数整合了所有的 api,setup 函数只执行一次,在生命周期函数前执行,所以在 setup 函数中拿不到当前实例 this,不能用 this 来调用 vue2 写法中定义的方法。
vue3 中去掉了 data,使用 setup 的返回值来给模板绑定value return 的对象如果是常量,不会变成响应式数据。
this.$emit 用 context.emit 方法来替代。
生命周期函数,都变成了回调的形式,写在setup函数中 可以一次写多个相同的生命周期函数,按照注册顺序执行。
defineProperty 来处理的。 通过 ref 包装的值,取值和设置值的时候,需用通过 value 来进行设置this.$refs 的写法。使用 reactive 来对复杂数据进行响应式处理,它的返回值是一个 proxy 对象,在 setup 函数中返回时,可以用 toRefs 对 proxy 对象进行结构,方便在 template 中使用。
通过 reactive 来创建响应式数据 data ,用 toRefs 来进行解构,在模板中直接使用 inputVal、todoList。
模板中绑定的方法也需要 在setup函数中定义,并返回,才能绑定到模板中,例如addTodo方法。
vue3 模板:一个 templage 可以有多个平级的标签(vue2中只能在template写一个子标签)
计算属性,变成了函数写法,当依赖的值发生改变时会重新计算 computed 包装后的值,需要用 .value 去取值,template 中不需要使用 .value。
变成了函数写法,与vue2中用法相同。
响应式地跟踪函数中引用的响应式数据,当响应式数据改变时,会重新执行函数。
组件中使用路由时用useRoute和useRouter。
使用 useStore 来获取 store 对象 从 vuex 中取值时,要注意必须使用 computed 进行包装,这样 vuex 中状态修改后才能在页面中响应。
vue3 中支持使用 jsx 语法来定义 vue 组件。
proxy 的方式实现数据代理,只会代理第一层数据 避免了vue2中对data的深层递归,提升了组件渲染性能。上例中,返回的state是一个 proxy 对象,默认只会对 data 进行代理 那么vue3是怎么实现深层数据劫持呢,例如我们要修改obj那么是怎么监听到obj的修改呢? 当我们要对深层对象obj进行修改时,会调用 state.data 的 get 方法,在 get 方法中会对 state.data 进行代理,劫持 state.data 中的属性, get 方法返回的不是 state.data 本身,而是被 proxy 代理过的对象,从而巧妙的实现了深层数据劫持,在用到该属性的时候一定会调用父级的 get 方法,这时候才会去劫持属性的 get 和 set 方法。
vue3 中用 setup 函数整合了所有的 api,setup 函数只执行一次,在生命周期函数前执行,所以在 setup 函数中拿不到当前实例 this,不能用 this 来调用 vue2 写法中定义的方法。
vue3 中去掉了 data,使用 setup 的返回值来给模板绑定value return 的对象如果是常量,不会变成响应式数据。
this.$emit 用 context.emit 方法来替代。
生命周期函数,都变成了回调的形式,写在setup函数中 可以一次写多个相同的生命周期函数,按照注册顺序执行。
defineProperty 来处理的。 通过 ref 包装的值,取值和设置值的时候,需用通过 value 来进行设置this.$refs 的写法。使用 reactive 来对复杂数据进行响应式处理,它的返回值是一个 proxy 对象,在 setup 函数中返回时,可以用 toRefs 对 proxy 对象进行结构,方便在 template 中使用。
通过 reactive 来创建响应式数据 data ,用 toRefs 来进行解构,在模板中直接使用 inputVal、todoList。
模板中绑定的方法也需要 在setup函数中定义,并返回,才能绑定到模板中,例如addTodo方法。
vue3 模板:一个 templage 可以有多个平级的标签(vue2中只能在template写一个子标签)
计算属性,变成了函数写法,当依赖的值发生改变时会重新计算 computed 包装后的值,需要用 .value 去取值,template 中不需要使用 .value。
变成了函数写法,与vue2中用法相同。
响应式地跟踪函数中引用的响应式数据,当响应式数据改变时,会重新执行函数。
组件中使用路由时用useRoute和useRouter。
使用 useStore 来获取 store 对象 从 vuex 中取值时,要注意必须使用 computed 进行包装,这样 vuex 中状态修改后才能在页面中响应。
vue3 中支持使用 jsx 语法来定义 vue 组件。