## 启动流程
### 项目部署
- yarn install
### 项目启动
想启动哪个项目,就把那个项目名字重命名为src
然后执行 `yarn serve`
## 1.Vue3简介
- 2020年9月18日,Vue.js发布3.0版本,代号:One Piece(海贼王)
- 耗时2年多、[2600+次提交](https://github.com/vuejs/vue-next/graphs/commit-activity)、[30+个RFC](https://github.com/vuejs/rfcs/tree/master/active-rfcs)、[600+次PR](https://github.com/vuejs/vue-next/pulls?q=is%3Apr+is%3Amerged+-author%3Aapp%2Fdependabot-preview+)、[99位贡献者](https://github.com/vuejs/vue-next/graphs/contributors)
- github上的tags地址:https://github.com/vuejs/vue-next/releases/tag/v3.0.0
## 2.Vue3带来了什么
### 1.性能的提升
- 打包大小减少41%
- 初次渲染快55%, 更新渲染快133%
- 内存减少54%
......
### 2.源码的升级
- 使用Proxy代替defineProperty实现响应式
- 重写虚拟DOM的实现和Tree-Shaking
......
### 3.拥抱TypeScript
- Vue3可以更好的支持TypeScript
### 4.新的特性
1. Composition API(组合API)
- setup配置
- ref与reactive
- watch与watchEffect
- provide与inject
- ......
2. 新的内置组件
- Fragment
- Teleport
- Suspense
3. 其他改变
- 新的生命周期钩子
- data 选项应始终被声明为一个函数
- 移除keyCode支持作为 v-on 的修饰符
- ......
# 一、创建Vue3.0工程
## 1.使用 vue-cli 创建
官方文档:https://cli.vuejs.org/zh/guide/creating-a-project.html#vue-create
```bash
## 查看@vue/cli版本,确保@vue/cli版本在4.5.0以上
vue --version
## 安装或者升级你的@vue/cli
npm install -g @vue/cli
## 创建
vue create vue_test
## 启动
cd vue_test
npm run serve
```
## 2.使用 vite 创建
官方文档:https://v3.cn.vuejs.org/guide/installation.html#vite
vite官网:https://vitejs.cn
- 什么是vite?—— 新一代前端构建工具。
- 优势如下:
- 开发环境中,无需打包操作,可快速的冷启动。
- 轻量快速的热重载(HMR)。
- 真正的按需编译,不再等待整个应用编译完成。
- 传统构建 与 vite构建对比图
<img src="https://cn.vitejs.dev/assets/bundler.37740380.png" style="width:500px;height:280px;float:left" /><img src="https://cn.vitejs.dev/assets/esm.3070012d.png" style="width:480px;height:280px" />
```bash
## 创建工程
npm init vite-app <project-name>
## 进入工程目录
cd <project-name>
## 安装依赖
npm install
## 运行
npm run dev
```
# 二、常用 Composition API
官方文档: https://v3.cn.vuejs.org/guide/composition-api-introduction.html
## 1.拉开序幕的setup
1. 理解:Vue3.0中一个新的配置项,值为一个函数。
2. setup是所有<strong style="color:#DD5145">Composition API(组合API)</strong><i style="color:gray;font-weight:bold">“ 表演的舞台 ”</i>。
4. 组件中所用到的:数据、方法等等,均要配置在setup中。
5. setup函数的两种返回值:
1. 若返回一个对象,则对象中的属性、方法, 在模板中均可以直接使用。(重点关注!)
2. <span style="color:#aad">若返回一个渲染函数:则可以自定义渲染内容。(了解)</span>
6. 注意点:
1. 尽量不要与Vue2.x配置混用
- Vue2.x配置(data、methos、computed...)中<strong style="color:#DD5145">可以访问到</strong>setup中的属性、方法。
- 但在setup中<strong style="color:#DD5145">不能访问到</strong>Vue2.x配置(data、methos、computed...)。
- 如果有重名, setup优先。
2. setup不能是一个async函数,因为返回值不再是return的对象, 而是promise, 模板看不到return对象中的属性。(后期也可以返回一个Promise实例,但需要Suspense和异步组件的配合)
## 2.ref函数
- 作用: 定义一个响应式的数据
- 语法: ```const xxx = ref(initValue)```
- 创建一个包含响应式数据的<strong style="color:#DD5145">引用对象(reference对象,简称ref对象)</strong>。
- JS中操作数据: ```xxx.value```
- 模板中读取数据: 不需要.value,直接:```<div>{{xxx}}</div>```
- 备注:
- 接收的数据可以是:基本类型、也可以是对象类型。
- 基本类型的数据:响应式依然是靠``Object.defineProperty()``的```get```与```set```完成的。
- 对象类型的数据:内部 <i style="color:gray;font-weight:bold">“ 求助 ”</i> 了Vue3.0中的一个新函数—— ```reactive```函数。
## 3.reactive函数
- 作用: 定义一个<strong style="color:#DD5145">对象类型</strong>的响应式数据(基本类型不要用它,要用```ref```函数)
- 语法:```const 代理对象= reactive(源对象)```接收一个对象(或数组),返回一个<strong style="color:#DD5145">代理对象(Proxy的实例对象,简称proxy对象)</strong>
- reactive定义的响应式数据是“深层次的”。
- 内部基于 ES6 的 Proxy 实现,通过代理对象操作源对象内部数据进行操作。
## 4.Vue3.0中的响应式原理
### vue2.x的响应式
- 实现原理:
- 对象类型:通过```Object.defineProperty()```对属性的读取、修改进行拦截(数据劫持)。
- 数组类型:通过重写更新数组的一系列方法来实现拦截。(对数组的变更方法进行了包裹)。
```js
Object.defineProperty(data, 'count', {
get () {},
set () {}
})
```
- 存在问题:
- 新增属性、删除属性, 界面不会更新。
- 直接通过下标修改数组, 界面不会自动更新。
### Vue3.0的响应式
- 实现原理:
- 通过Proxy(代理): 拦截对象中任意属性的变化, 包括:属性值的读写、属性的添加、属性的删除等。
- 通过Reflect(反射): 对源对象的属性进行操作。
- MDN文档中描述的Proxy与Reflect:
- Proxy:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Proxy
- Reflect:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Reflect
```js
new Proxy(data, {
// 拦截读取属性值
get (target, prop) {
return Reflect.get(target, prop)
},
// 拦截设置属性值或添加新属性
set (target, prop, value) {
return Reflect.set(target, prop, value)
},
// 拦截删除属性
deleteProperty (target, prop) {
return Reflect.deleteProperty(target, prop)
}
})
proxy.name = 'tom'
```
## 5.reactive对比ref
- 从定义数据角度对比:
- ref用来定义:<strong style="color:#DD5145">基本类型数据</strong>。
- reactive用来定义:<strong style="color:#DD5145">对象(或数组)类型数据</strong>。
- 备注:ref也可以用来定义<strong style="color:#DD5145">对象(或数组)类型数据</strong>, 它内部会自动通过```reactive```转为<strong style="color:#DD5145">代理对象</strong>。
- 从原理角度对比:
- ref通过``Object.defineProperty()``的```get```与```set```来实现响应式(数据劫持)。
- reactive通过使用<strong style="color:#DD5145">Proxy</strong>来实现响应式(数据劫持), 并通过<strong style="color:#DD5145">Reflect</strong>操作<strong style="color:orange">源对象</strong>内部的数据。
- 从使用角度对比:
- ref定义的数据:操作数据<strong style="color:#DD5145">需要</strong>```.value```,读取数据时模板中直接读取<strong style="color:#DD5145">不需要</strong>```.value```。
- reactive定义的数据:操作数据与读取数据:<strong style="color:#DD5145">均不需要</strong>```.value```。
## 6.setup的两个注�
没有合适的资源?快使用搜索试试~ 我知道了~
vue基础知识面试题.zip 包含 vue2 和 vue3
共1591个文件
ts:609个
vue:423个
png:111个
需积分: 0 3 下载量 100 浏览量
2024-01-23
11:29:08
上传
评论 1
收藏 9.72MB ZIP 举报
温馨提示
vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vue2 和 vue3 vue基础知识面试题.zip 包含 vu
资源推荐
资源详情
资源评论
收起资源包目录
vue基础知识面试题.zip 包含 vue2 和 vue3 (1591个子文件)
.env.base 140B
.eslintrc.cjs 2KB
.eslintrc.cjs 2KB
.stylelintrc.cjs 2KB
.stylelintrc.cjs 2KB
.eslintrc.cjs 1KB
.eslintrc.cjs 1KB
commitlint.config.cjs 695B
commitlint.config.cjs 356B
commit-msg 116B
commit-msg 91B
commit-msg 70B
commit-msg 69B
commit-msg 67B
index-88d93745.css 319KB
skin.min.css 60KB
skin.min.css 60KB
animate.min.css 57KB
content.min.css 21KB
content.inline.min.css 21KB
content.inline.min.css 21KB
content.min.css 21KB
skin.mobile.min.css 21KB
skin.mobile.min.css 21KB
index-71e0f63f.css 14KB
style.css 2KB
index-b5d19621.css 1KB
var.css 1KB
skin.shadowdom.min.css 783B
skin.shadowdom.min.css 783B
index-4f70bfcc.css 547B
content.mobile.min.css 544B
content.mobile.min.css 544B
index-5d21f557.css 437B
index-17bee9d3.css 393B
index-4399a34c.css 265B
index-571acc3c.css 210B
index-2472d4cb.css 98B
index-11e82475.css 86B
.env.dev 324B
.env.development 523B
.env.development 344B
.env.development 195B
.env.development 28B
.editorconfig 575B
.editorconfig 257B
.env 330B
.env 129B
.eslintignore 130B
.eslintignore 100B
.eslintignore 87B
.eslintignore 24B
.eslintignore 24B
.eslintignore 17B
.eslintignore 17B
.env.gitee 337B
.gitignore 350B
.gitignore 348B
.gitignore 302B
.gitignore 253B
.gitignore 253B
.gitignore 253B
.gitignore 253B
.gitignore 248B
.gitignore 231B
.gitignore 72B
component.hbs 262B
view.hbs 185B
index.hbs 99B
index.html 6KB
index.html 4KB
index.html 4KB
01hello.html 3KB
index.html 3KB
Vue3响应式原理.html 2KB
08-2click.html 2KB
12-2-3myprop.html 2KB
12-2-2prop-childtoroot.html 2KB
02scale实现数据大屏适配问题.html 2KB
09v-model.html 2KB
05computed.html 2KB
03-1v-for.html 2KB
index.html 2KB
04template.html 1KB
12-2-1prop-childtoroot.html 1KB
10-3transition.html 1KB
10-1transition.html 1KB
10-2transition.html 1KB
07-4style_3.html 1KB
07-1style_0.html 1KB
07-2style_1.html 1KB
06watch.html 1KB
02-2v-show.html 1KB
07-3style_2.html 1KB
12-1prop-roottochild.html 1KB
02-3tab.html 990B
01vw与vh单位解决适配问题.html 959B
03-2v-for_key.html 843B
02-1v-if.html 839B
08-3click.html 718B
共 1591 条
- 1
- 2
- 3
- 4
- 5
- 6
- 16
资源评论
张无忌打怪兽
- 粉丝: 2056
- 资源: 1197
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 全景拼接python旗舰版
- FFmpeg n4.2.9版本库 可用于win7 64位系统上音视频开发
- 新松协助机器人SR9900A网页打不开的话,重新安装一次驱动就可以了
- 基于深度学习的yo lo火灾监测预警系统高分项目.zip
- MIS6611-VB一款P-Channel沟道SOT23-6的MOSFET晶体管参数介绍与应用说明
- AutoSAR个人笔记-
- jdk-8u144-linux-x64资源
- FFmpeg 4.2.2版本库可用于32位系统,支持视频编解码、rtsp流协议等
- 软件项目招标文件技术标书撰写与开发解决方案
- 基于PyQt5、Python与MySQL的酒店信息管理系统+高分项目+源码.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功