Vue.js 3.x+Element Plus从入门到精通(视频教学版)
上QQ阅读APP看书,第一时间看更新

1.3 Vue.js概述

Vue.js是一套构建前端的MVVM框架,它集合了众多优秀主流框架设计的思想,轻量、数据驱动、学习成本低,而且可与webpack/gulp构建工具结合以实现Web组件化开发、构建和部署等。

Vue.js本身就拥有一套较为成熟的生态系统:Vue+vue-router+Vuex+Webpack+ Sass/Less,不仅满足小的前端项目开发,也能胜任大型的前端应用开发,包括单页面应用和多页面应用等。Vue.js可实现前端页面和后端业务分离、快速开发、单元测试、构建优化、部署等。

提到前端框架,当下比较流行的有Vue.js、React.js和Angular.js。Vue.js以其容易上手的API、不俗的性能、渐进式的特性和活跃的社区从中脱颖而出。截至目前,Vue.js在GitHub上的受欢迎程度已经超过了其他的前端开发框架,成为最热门的框架。

Vue.js的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue.js也完全能够为复杂的单页应用提供驱动。

1.3.1 Vue.js“组件化”思想

Vue.js的目标就是通过尽可能简单的API实现响应、数据绑定和组合的视图组件,核心是一个响应的数据绑定系统。Vue.js被定义成一个用来开发Web界面的前端框架,是个非常轻量级的工具。使用Vue.js可以让Web开发变得简单,同时也颠覆了传统前端开发的模式。

Vue.js是渐进式的JavaScript框架,如果已经有一个现成的服务端应用,可以将Vue.js作为该应用的一部分嵌入其中,带来更加丰富的交互体验。或者,如果希望将更多的业务逻辑放到前端来实现,那么Vue.js的核心库及其生态系统也可以满足用户的各种需求。

和其他前端框架一样,Vue.js允许将一个网页分割成可复用的组件,每个组件都包含属于自己的HTML、CSS和JavaScript,如图1-3所示,以用来渲染网页中相应的地方。

图1-3 组件化

这种把网页分割成可复用组件的方式就是框架“组件化”的思想。

Vue.js组件化的理念和React异曲同工——“一切皆组件”。Vue.js可以将任意封装好的代码注册成组件,例如Vue.component('example',Example),可以在模板中以标签的形式调用。

example是一个对象,组件的参数配置经常使用到template,它是组件将要渲染的HTML内容。例如,example组件的调用方式如下:

     <body>
     <h1>我是主页</h1>
     <!-- 在模板中调用example组件 -->s
     <example></example>
     <p>欢迎访问我们的网站</p>
     </body>

如果组件设计合理,在很大程度上可以减少重复开发,而且配合Vue.js的单文件组件(vue-loader),可以将一个组件的CSS、HTML和JavaScript都写在一个文件中,做到模块化的开发。此外,Vue.js也可以与vue-router和vue-resource插件配合起来,以支持路由和异步请求,这样就满足了开发单页面应用程序的基本条件。

在Vue.js中,单文件组件是指一个后缀名为.vue的文件,它可以由各种各样的组件组成,大至一个页面组件,小至一个按钮组件。在后面的章节将详细介绍单文件组件的实现。

Vue.js正式发布于2014年2月,包含70多位开发人员的贡献。从脚手架、构建、组件化、插件化,到编辑器工具、浏览器插件等,基本涵盖了从开发到测试的多个环节。

1.3.2 Vue.js的发展历程

Vue.js的发展过程如下:

2013年12月24日,发布0.7.0。

2014年1月27日,发布0.8.0。

2014年2月25日,发布0.9.0。

2014年3月24日,发布0.10.0。

2015年10月27日,正式发布1.0.0。

2016年4月27日,发布2.0的Preview版本。

2017年第一个发布的Vue.js为v2.1.9,最后一个发布的Vue.js为v2.5.13。

2019年发布Vue.js的2.6.10版本,也是比较稳定的版本。

2020年9月18日,Vue.js 3.0正式发布。

2023年12月28日,Vue.js 3.4正式发布。

1.3.3 Vue.js 3.4的特性

目前,Vue.js的版本已经更新到3.4,这次更新不仅带来了性能上的飞跃,还引入了许多新特性,进一步优化了开发效率。

1.性能提升

在性能方面,Vue.js 3.4全新重写了模板解析器。与之前基于正则表达式的解析器相比,新的解析器通过单次遍历整个模板字符串来解析模板,显著提高了解析速度,模板解析器速度提高了2倍。无论是小型还是大型的Vue.js模板,新解析器都能保持2倍的性能提升,同时确保了向后兼容性。

2.重构响应系统

Vue.js 3.4重构了响应系统。在旧版本中,即使计算属性的结果未发生变化,每次依赖项更新,观察者也会被触发。而在Vue.js 3.4中,优化后的系统确保只有在计算结果实际变化时,相关的效果才会被触发,从而减少了组件的不必要渲染,提升了整体的性能。

3.API改进与新特性

Vue.js 3.4中引入了非常多的新特性,主要更新如下:

(1)defineModel API的稳定化及功能:这个API主要用于简化支持v-model的组件实现,并在新版本中增加了对v-model修饰符的支持。

(2)v-bind的同名简写功能:Vue.js 3.4引入了v-bind的同名简写功能,使得开发者在模板中绑定属性时,可以省略重复的变量名。当属性名和绑定的变量名相同时,可以直接使用属性名,从而使模板更加简洁。

(3)watch新增once选项:Vue.js 3.4为watch函数增加了once选项,这使得观察者在第一次检测到变化时就会停止,适用于只需响应一次数据变化的场景。这个新选项提供了一种简洁的方式来防止重复触发。

(4)对MathML的支持:Vue.js 3.4对MathML的支持,意味着开发者现在可以在Vue应用中直接使用MathML来呈现数学公式和符号。MathML是一种标记语言,用于描述数学公式的结构和内容。这一功能的加入使得Vue.js适用于更广泛的应用场景,特别是在需要展示复杂数学内容的教育和科学出版领域。