Web前端最全vue3 到底哪里好?看这一篇就够了,吊打面试官系列

最后

总的来说,面试官要是考察思路就会从你实际做过的项目入手,考察你实际编码能力,就会让你在电脑敲代码,看你用什么编辑器、插件、编码习惯等。所以我们在回答面试官问题时,有一个清晰的逻辑思路,清楚知道自己在和面试官说项目说技术时的话就好了

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

但是因为是同一个函数,所以不用追踪变化,直接缓存起来复用即可

3> ssr渲染

当存在大量静态内容时,这些内容会被当做纯字符串推进一个 buffer 内,即使存在动态绑定,也会通过模板插值潜入进去,这样会比虚拟 DOM 渲染快得多。

2.2、代码体积方面

打包大小减少41%。

vue3 移除了一些不常用的 API,如:inline-template、filter 等,使用 tree-shaking。

Tree Shaking 摇树优化,指的就是当我们引入一个模块的时候,不引入这个模块的所有代码,只引入我们需要的代码。

在 vue2 中,很多函数都挂载到全局 Vue 对象上,如:nextTick、set 函数等,虽然我们不常用,但打包时只要引入 Vue 这些全局函数会打包进 bundle 中。而 vue3 中,引入tree-shaking,所有的 API 都通过 ES6 模块化的方式引入,这样就能够让 webpack 或 rollup 等打包工具在打包时,就会自动对没有用到的 API 进行剔除,最小化 bundle 体积。

初次渲染快55%, 更新渲染快133%。组件选择了按需引入,使得打包后的体积也更小了,所以项目运行的时候速度更快,更顺畅了!

2.3、编译被优化

1> 静态提升

在 vue2 中,无论元素是否参与更新,每次都会重新创建然后再渲染。

vue3 使用静态提升后,对于不参与更新的元素,只会被创建一次,在渲染时直接复用就好了。

2> Fragment

模板内不用再创建一个唯一根节点,可以直接放同级标签和内容。就相当于少了一个节点嵌套渲染。

三、选项式 api VS 组合式 api


3.1、vue3 的组合式 api 相对来说,更有利于维护和封装。

3.2、组合式 api 高内聚,低耦合。

在 vue2 中采用选项式 api ,会在 vue 文件的 data、methods、watch、computed 中定义属性和方法,共同处理页面逻辑,多个功能相互交叉,缠绕在一起,代码过于分散。

而 vue3 新增了组合式 api ,一个功能模块代码会集中到一起,实现高内聚,低耦合。提高代码的可读性和可维护性,基于函数组合的 api 更好地重用逻辑代码。

组合式api 与 选项式api 对比如下图:

每个颜色,都代表着一个功能。

vue3 到底哪里好?看这一篇就够了

3.3、不宜出现 DOM 元素不存在问题。

vue3 中用 setup 函数代替了 vue2 中的 beforeCreate 和 created 。有些同学有时候会在 created 中操作 DOM 元素,有时候报错了,就在那纳闷看不出来问题,为了没有反应。使用 setup 之后,就不容易出现该问题了。

注意:

vue3 的组合式 api 中的 onUnmounted 代替了 vue2 中的 beforeDestory。

vue3 的组合式 api unmounted 代替了 vue2 中的 destoryed 。

四、proxy 相对 Object.defineProperty 优点有哪些?


proxy 和 Object.defineProperty 都是来实现响应式数据的。

vue3 使用 proxy 来代替 vue2 的 Object.defineProperty 效率更高,值得学习。

1> vue2 利用 Object.defineProperty 来劫持 data 数据的 getter 和 setter 操作,使得 data 在被访问或赋值时,动态更新绑定的 template 模板。而 Object.defineProperty 必须遍历所有的预值才能劫持每一个属性,这一缺点正好能够被 proxy 解决。

proxy 相比 Object.defineProperty 优点分别为:

  • 代码的执行效果更快。

  • proxy 可以直接监听对象而不是它的属性。

  • proxy 可以直接监听数组的每个元素的变化。

  • proxy 不需要初始化的时候遍历所有属性,如果有多层嵌套的话,只访问某个属性的时候,proxy 能够快速访问到,而 Object.defineProperty 还需要遍历所有属性,然后逐级向下访问。

  • proxy 返回的是一个新对象,可以直接操作新对象而达到目标。而 Object.defineProperty 操作的是原对象,只能遍历对象属性然后对其直接修改。

  • proxy 有 13 种拦截方法,不限于 apply、ownKeys、deleteProperty 等,而 Object.defineporperty 不具备。

2> defineProperty 无法监听对象新增属性以及无法跟踪数组索引以及数组 length 的问题,proxy 正好解决了该问题。

在 vue2 中,我们给对象新增一个属性时,如果新增属性的值发生改变的时候,我们发现视图并没有更新,因为新增属性是无法监听到的。同样的,通过下标直接改变数组,视图也是无法更新的,也是因为监听不到。

在 vue3 中新增 proxy ,解决了这些问题。

五、更好的 ts 支持


vue2 不适合使用 ts,在于它的 Options API 风格。

options 是一个简单的对象,而 ts 是一种类型系统、面向对象的语法,两个不匹配。

vue3 新增了 defineComponent 函数,使组件在 ts 下,更好的利用参数类型推断。如:reactive 和 ref 很具有代表性。

分享

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

a486d4c3ab8389e65ecb71ac0)**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值