vue3做了哪些改变?(未完待整理)

在使用的层面,我们从options Api(options Api的写法,比如data、computed、watch、methods等等),变成了composition Api,慢慢的在实际的业务中,我们抛弃了原本的data、methods、computed那种隔离式的写法。同时,在composition Api中,为了防止过于重的业务逻辑,它提供了一种关注点分离的方式,大大的提升了我们代码的可读性。在diff算法上,使用了静态标记的方式,大大提升了Vue的执行效率。.........
摘要由CSDN通过智能技术生成

使用 proxy 代替之前的 Object.defineProperty 的API,性能更加优异,也解决了之前vue在处理对象、数组上的缺陷;在diff算法上,使用了静态标记的方式,大大提升了Vue的执行效率。

在使用的层面,我们从options Api(options Api的写法,比如data、computed、watch、methods等等),变成了composition Api,慢慢的在实际的业务中,我们抛弃了原本的data、methods、computed那种隔离式的写法。compositon Api,它更加聚焦,它讲究的是相关业务的聚合性。

同时,在composition Api中,为了防止过于重的业务逻辑,它提供了一种关注点分离的方式,大大的提升了我们代码的可读性。Vue2的问题就是在于,聚合性不足,会导致代码越来越臃肿!setup的方式,能够让data、方法逻辑、依赖关系等聚合在一块,更方便维护。

完全良好的支持了TypeScript,类型校验也成为了以后Vue3进行大型项目开发的质量保障,同时这也是面向了趋势 -- 前端的未来就是TypeScript!

1、compositon Api

compositon Api的本质,体现在代码里面,也就是一个setup函数,在这个setup函数中,返回的数据,会用到该组件的模板中。return的这个对象,一定程度上,代表了之前vue2中的data属性。

import { defineComponent, ref } from 'vue';
export default defineComponent({ 
    name: 'Gift',   
    setup() {     
        const counter = ref(0);    
        return {        
            counter     
        }  
    }
})

 这时候,对于大多数初学者来说,可能存在的疑惑就是,那么我能不能定义options Api的写法,比如data、computed、watch、methods等等。

这里我需要明确的是,Vue3是完全兼容Vue2的这种options Api的写法,但是从理念上来说,更加推荐setup的方式,来写我们的组件。

原因如下:Vue3的存在,本身是为了解决Vue2的问题的,Vue2的问题就是在于,聚合性不足,会导致代码越来越臃肿!setup的方式,能够让data、方法逻辑、依赖关系等聚合在一块,更方便维护。

也就是说,以后我们

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Vue 3相比于Vue 2提升了更快的渲染速度,更好的类型安全性,更灵活的组件通信机制,更强大的路由系统,更容易的服务器端渲染,更全面的 TypeScript 支持,更优化的代码结构,以及新的调试工具。 ### 回答2: Vue 3相比于Vue 2在以下几个方面有了明显的提升。 1. 性能提升:Vue 3通过优化虚拟DOM的算法和编译器,显著提高了性能。新的响应式系统使用了基于Proxy的数据劫持,比Vue 2的Object.defineProperty更高效,能够更好地追踪数据的变化。 2. 打包体积减小:Vue 3移除了一些过时的API,整个库的打包体积比Vue 2减小了约30%,减轻了网络传输负担,提速了页面加载速度。 3. 组合式API:Vue 3引入了组合式API,使得组件逻辑可以更加清晰地组织和重用。开发者可以通过API自由组合逻辑代码,更好地划分功能,提高了代码的可维护性。 4. TypeScript支持:Vue 3对TypeScript的支持更加友好,大部分核心API都有了相应的类型声明,开发者可以更早地发现潜在的错误,并且编辑器能够提供更好的代码提示和补全。 5. 更好的升级途径:Vue 3可以与Vue 2共存,并提供了更好的升级途径。Vue 3提供了一个逐步升级的工具,帮助开发者平滑过渡到新版本,从而降低了升级的风险。 总的来说,Vue 3在性能、打包体积、API设计、TypeScript支持和升级途径等方面都有了明显的提升,使得开发者能够更加高效、舒适地使用Vue进行开发。 ### 回答3: Vue 3相比于Vue 2在性能、体积、使用体验和开发者工具等方面有了很多提升。 首先是性能方面的提升。Vue 3通过使用Proxy代理对象替代了Vue 2中的Object.defineProperty方法,使得响应式系统的性能得到了显著提升。此外,Vue 3还引入了静态树优化和组件级别的缓存优化,可以减少不必要的渲染操作,提高页面性能。 其次是体积方面的提升。Vue 3采用了更好的Tree-Shaking机制和模块化设计,可以让开发者只引入所需的功能代码,从而减小项目的体积。这使得Vue 3在移动端和网络环境较差的情况下有更好的表现。 再者,Vue 3在使用体验方面也有了很多提升。Vue 3引入了Composition API,提供了更加灵活的组合式编程方式,使得代码逻辑更加清晰和可维护。此外,Vue 3还提供了更好的TypeScript支持,让开发者在开发过程中能够更快速、更准确地发现错误。 最后,开发者工具方面也有了很多改进。Vue 3的开发者工具更加强大和易用,提供了更多的工具和功能,如更好的性能监控和调试工具等,可以帮助开发者更高效地进行开发和调试工作。 总结来说,Vue 3相比于Vue 2在性能、体积、使用体验和开发者工具等方面都有了明显的提升,使得开发者能够更加高效、更加愉快地开发Vue应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值