简述Vue3.0 为什么要用 proxy ?
Vue 3.0选择使用Proxy是出于以下几个原因:
- 性能:Proxy对象可以直接监视对象的变化,而不需要像Vue 2.x版本那样遍历对象的所有属性并添加getter和setter。这样可以大大提高性能。
-
功能:Proxy可以直接监视数组的变化,也可以监视对象的新增和删除属性,这是Vue 2.x版本的Object.defineProperty做不到的。
-
简洁:使用Proxy可以使内部实现更加简洁,减少源码的复杂度。
举个例子,假设我们有一个用户对象,我们需要在用户的姓名改变时更新一些UI。在Vue 2.x中,我们需要为这个对象的每个属性创建一个getter和setter,当属性被访问或修改时,我们可以执行一些额外的逻辑。但是这种方式在处理大对象或者嵌套对象时,性能会下降。
但在Vue 3.0中,我们可以直接用Proxy去包裹整个对象,当任何属性被访问或者修改时,我们都可以拦截到,而且还可以监视到新增或者删除属性的操作。这样无论对象有多大,或者有多深的嵌套,性能都可以保持在一个很高的水平。