2020年9月18日,Vue.js
发布版3.0
版本,代号:One Piece
(n
经历了:4800+次提交、40+个RFC、600+次PR、300+贡献者
官方发版地址:Release v3.0.0 One Piece · vuejs/core
截止2023年10月,最新的公开版本为:3.3.4
打包大小减少41%
。
初次渲染快55%
, 更新渲染快133%
。
内存减少54%
。
使用Proxy
代替defineProperty
实现响应式。
重写虚拟DOM
的实现和Tree-Shaking
。
Vue3
可以更好的支持TypeScript
。Composition API
(组合API
):
setup
ref
与reactive
computed
与watch
…
新的内置组件:
Fragment
Teleport
Suspense
…
其他改变:
新的生命周期钩子
data
选项应始终被声明为一个函数
移除keyCode
支持作为 v-on
的修饰符
…
点击查看官方文档
备注:目前
vue-cli
已处于维护模式,官方推荐基于Vite
创建项目。
## 查看@vue/cli版本,确保@vue/cli版本在4.5.0以上
vue --version
## 安装或者升级你的@vue/cli
npm install -g @vue/cli
## 执行创建命令
vue create vue_test
## 随后选择3.x
## Choose a version of Vue.js that you want to start the project with (Use arrow keys)
## > 3.x
## 2.x
## 启动
cd vue_test
npm run serve
vite
是新一代前端构建工具,官网地址:https://vitejs.cn,vite
的优势如下:
HMR
),能实现极速的服务启动。TypeScript
、JSX
、CSS
等支持开箱即用。webpack
构建 与 vite
构建对比图如下:## 1.创建命令
npm create vue@latest
## 2.具体配置
## 配置项目名称
√ Project name: vue3_test
## 是否添加TypeScript支持
√ Add TypeScript? Yes
## 是否添加JSX支持
√ Add JSX Support? No
## 是否添加路由环境
√ Add Vue Router for Single Page Application development? No
## 是否添加pinia环境
√ Add Pinia for state management? No
## 是否添加单元测试
√ Add Vitest for Unit Testing? No
## 是否添加端到端测试方案
√ Add an End-to-End Testing Solution? » No
## 是否添加ESLint语法检查
√ Add ESLint for code quality? Yes
## 是否添加Prettiert代码格式化
√ Add Prettier for code formatting? No
自己动手编写一个App组件
你好啊!
安装官方推荐的vscode
插件:
总结:
Vite
项目中,index.html
是项目的入口文件,在项目最外层。index.html
后,Vite
解析
指向的JavaScript
。Vue3
**中是通过 **createApp
函数创建一个应用实例。Vue3
向下兼容Vue2
语法,且Vue3
中的模板中可以没有根标签
姓名:{
{name}}
年龄:{
{age}}
Vue2
的API
设计是Options
(配置)风格的。Vue3
的API
设计是Composition
(组合)风格的。Options
类型的 API
,数据、方法、计算属性等,是分散在:data
、methods
、computed
中的,若想新增或者修改一个需求,就需要分别修改:data
、methods
、computed
,不便于维护和复用。
可以用函数的方式,更加优雅的组织代码,让相关功能的代码更加有序的组织在一起。
说明:以上四张动图原创作者:大帅老猿
setup
是Vue3
中一个新的配置项,值是一个函数,它是 Composition API
“表演的舞台”,组件中所用到的:数据、方法、计算属性、监视…等等,均配置在setup
中。
特点如下:
setup
函数返回的对象中的内容,可直接在模板中使用。setup
中访问this
是undefined
。setup
函数会在beforeCreate
之前调用,它是“领先”所有钩子执行的。
姓名:{
{name}}
年龄:{
{age}}
setup(){
return ()=> '你好啊!'
}
Vue2
的配置(data
、methos
…)中可以访问到 setup
中的属性、方法。setup
中不能访问到Vue2
的配置(data
、methos
…)。Vue2
冲突,则setup
优先。setup
函数有一个语法糖,这个语法糖,可以让我们把setup
独立出去,代码如下:
姓名:{
{name}}
年龄:{
{age}}
扩展:上述代码,还需要编写一个不写setup
的script
标签,去指定组件名字,比较麻烦,我们可以借助vite
中的插件简化
npm i vite-plugin-vue-setup-extend -D
vite.config.ts
import { defineConfig } from 'vite'
import VueSetupExtend from 'vite-plugin-vue-setup-extend'
export default defineConfig({
plugins: [ VueSetupExtend() ]
})
let xxx = ref(初始值)
。RefImpl
的实例对象,简称ref对象
或ref
,ref
对象的value
属性是响应式的。JS
中操作数据需要:xxx.value
,但模板中不需要.value
,直接使用即可。let name = ref('张三')
来说,name
不是响应式的,name.value
是响应式的。
姓名:{
{name}}
年龄:{
{age}}
ref
,否则报错)let 响应式对象= reactive(源对象)
。Proxy
的实例对象,简称:响应式对象。reactive
定义的响应式数据是“深层次”的。
汽车信息:一台{
{ car.brand }}汽车,价值{
{ car.price }}万
游戏列表:
- {
{ g.name }}
测试:{
{obj.a.b.c.d}}
ref
接收的数据可以是:基本类型、对象类型。ref
接收的是对象类型,内部其实也是调用了reactive
函数。
汽车信息:一台{
{ car.brand }}汽车,价值{
{ car.price }}万
游戏列表:
- {
{ g.name }}
测试:{
{obj.a.b.c.d}}
宏观角度看:
ref
用来定义:基本类型数据、对象类型数据;
reactive
用来定义:对象类型数据。
ref
创建的变量必须使用.value
(可以使用volar
插件自动添加.value
)。
reactive
重新分配一个新对象,会失去响应式(可以使用Object.assign
去整体替换)。
- 若需要一个基本类型的响应式数据,必须使用
ref
。- 若需要一个响应式对象,层级不深,
ref
、reactive
都可以。- 若需要一个响应式对象,且层级较深,推荐使用
reactive
。
ref
对象。toRefs
与toRef
功能一致,但toRefs
可以批量转换。
姓名:{
{person.name}}
年龄:{
{person.age}}
性别:{
{person.gender}}
作用:根据已有数据计算出新数据(和Vue2
中的computed
作用一致)。
姓:
名:
全名:{
{fullName}}
Vue2
中的watch
作用一致)Vue3
中的watch
只能监视以下四种数据:
ref
定义的数据。reactive
定义的数据。- 函数返回一个值(
getter
函数)。- 一个包含上述内容的数组。
我们在Vue3
中使用watch
的时候,通常会遇到以下几种情况:
监视ref
定义的【基本类型】数据:直接写数据名即可,监视的是其value
值的改变。
情况一:监视【ref】定义的【基本类型】数据
当前求和为:{
{sum}}
监视ref
定义的【对象类型】数据:直接写数据名,监视的是对象的【地址值】,若想监视对象内部的数据,要手动开启深度监视。
注意:
若修改的是
ref
定义的对象中的属性,newValue
和oldValue
都是新值,因为它们是同一个对象。若修改整个
ref
定义的对象,newValue
是新值,oldValue
是旧值,因为不是同一个对象了。
情况二:监视【ref】定义的【对象类型】数据
姓名:{
{ person.name }}
年龄:{
{ person.age }}
监视reactive
定义的【对象类型】数据,且默认开启了深度监视。
情况三:监视【reactive】定义的【对象类型】数据
姓名:{
{ person.name }}
年龄:{
{ person.age }}
测试:{
{obj.a.b.c}}
监视ref
或reactive
定义的【对象类型】数据中的某个属性,注意点如下:
结论:监视的要是对象里的属性,那么最好写函数式,注意点:若是对象监视的是地址值,需要关注对象内部,需要手动开启深度监视。
情况四:监视【ref】或【reactive】定义的【对象类型】数据中的某个属性
姓名:{
{ person.name }}
年龄:{
{ person.age }}
汽车:{
{ person.car.c1 }}、{
{ person.car.c2 }}
监视上述的多个数据