2020年9月18日,Vue.js发布版3.0版本,代号:One Piece(海贼王)
截止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 -Dvite.config.tsimport { 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}}
地址:{{address}}