一、 Vue3与Vite构建工具简介
data:image/s3,"s3://crabby-images/507c1/507c1408ae61e9da3743fe1fa159a20163e4ce0c" alt=""
data:image/s3,"s3://crabby-images/a484e/a484e0f57e6a3ce34d30ef875a03512b9951ab01" alt=""
data:image/s3,"s3://crabby-images/8585b/8585bf8695a476a4330e5ee30ae92ab737d7d486" alt=""
data:image/s3,"s3://crabby-images/711a3/711a33b408746624781eca2f751ab1d8e40bd81c" alt=""
Vite构建工具(其他的打包工具有webpack,grunt,gulp)
data:image/s3,"s3://crabby-images/cd446/cd4465e9cdf89b14e81b29d7b168a06a8190d504" alt=""
data:image/s3,"s3://crabby-images/988d3/988d3a5322a86ed7cf15faa11e5b24bc072151c5" alt=""
data:image/s3,"s3://crabby-images/c54a5/c54a50ee6a714eb59d1e78931ae7d6eca1d2beb4" alt=""
二、创建Vue3项目
- vite在TypeScript结合使用上,直接开箱即用,不需要额外配置。
-
Vue3语法兼容Vue2语法。Vue3的setup与Vue2的data、methods可以同时存在使用,但是不建议这样操作,优先使用setup组合式返回值。setup是先于beforeCreate、data等钩子执行的,所以在data中可以通过this读取出setup返回值,反之不可。
构建1
data:image/s3,"s3://crabby-images/e1eb9/e1eb980f73ca6979a76ca210600c293bb53ec169" alt=""
data:image/s3,"s3://crabby-images/fe4d3/fe4d3a1f5d48b9e1a562610a24f72450284d1086" alt=""
data:image/s3,"s3://crabby-images/abc28/abc287234c9cde8b37010c8654fb07779aac2c25" alt=""
依赖添加异常,需要检查网络或代理时,尝试使用国内镜像源,这里经常会有小坑,更换为国内镜像源以提高稳定性:
1使用淘宝镜像:
npm config set registry https://registry.npmmirror.com
2.使用腾讯镜像:
npm config set registry https://mirrors.cloud.tencent.com/npm/
3.使用华为镜像:
npm config set registry https://repo.huaweicloud.com/repository/npm/
4.检查当前镜像源:
npm config get registry
三、Vue2与Vue3项目api区别
- Vue2使用选项式Api,Vue3使用组合式Api
-
template内,Vue3可以不需要根节点,Vue2必须包含唯一一个根节点。
vue2
hook组合式封装,发挥了Vue3组件化开发的魅力。
data:image/s3,"s3://crabby-images/8a742/8a7427602260d25c2a6c70026750689acdd442e7" alt=""
data:image/s3,"s3://crabby-images/41289/41289eec1cbd6d8e51fd45385b66c8d85c7d446a" alt=""
data:image/s3,"s3://crabby-images/b1908/b19083e2d7b7126dba1f1c21226f4d16b096c25e" alt=""
data:image/s3,"s3://crabby-images/069a0/069a063464ee5337475274e6bbe75bd409c126e2" alt=""
data:image/s3,"s3://crabby-images/80fc9/80fc982d587ce9af74f8cf891afba51a05307fc3" alt=""
四、ref与reactive响应式
-
基本类型的响应式数据,只能使用ref
data:image/s3,"s3://crabby-images/56f1d/56f1d100183bfc496aabe09371d2ffa4ceb5f08a" alt=""
-
对象类型的响应式数据
1.reactive方式,只能定义对象类型。在setup中只需要取出使用即可,如car.price=200触发响应式和赋值。
data:image/s3,"s3://crabby-images/e19fa/e19fabb57a923b5bdf294bd9dc5180278f5ba562" alt=""
2.ref处理对象类型响应式,底层使用的还是reactive
data:image/s3,"s3://crabby-images/e3f39/e3f397ff0f97f3c7d826387ee9cb498dce2f06f0" alt=""
data:image/s3,"s3://crabby-images/e0a8f/e0a8f83ede40181397da44bd40a860bfd647a39e" alt=""
-
ref和reactive区别
分配不同对象时,对于ref只需要car.value=新对象,而对于reactive需要借助Object.assign(被替换对象,新对象1,新对象2...)
data:image/s3,"s3://crabby-images/c517f/c517fc0117bd5a86cea04134b965f5d25411a0a8" alt=""
car.value=ref({brand:'五菱',price:50})替换赋值生成一个新对象
Object.assign(car,{brand:'五菱',price:50})对象内属性一一对应覆盖,还是原来的对象
data:image/s3,"s3://crabby-images/4bbaa/4bbaa654e869af43bef07f38889ee10dbca86324" alt=""
-
toRefs与 toRef 使用
作用:将一个响应式对象中的每一个属性,转换为ref 对象
备注::toRefs与 toRef 功能一致,但 toRefs 可以批量转换整个对象,toRef只能转指定值。结构体name修改,person内对应的属性值也会响应式变化。
data:image/s3,"s3://crabby-images/e2950/e2950a80d6506fd395afe04ee9f4779efb60842b" alt=""
-
响应式对象取值特殊情况
data:image/s3,"s3://crabby-images/6d62a/6d62a43d0de5be6aec9e74cea1d58ad47437c0b2" alt=""
五、计算属性
引入import { reactive,ref, toRef, toRefs,computed } from 'vue'
同样使用的时候通过computed 包裹要计算的内容函数
data:image/s3,"s3://crabby-images/e3185/e31850d5d59dec67f1637d1f0d2ee8864314a24b" alt=""
六、watch属性
data:image/s3,"s3://crabby-images/2ca31/2ca31b4d78855c806908741957ae11232c178e2f" alt=""
data:image/s3,"s3://crabby-images/64376/6437649b885ee631db060e9fbe6c6be466ffca99" alt=""
data:image/s3,"s3://crabby-images/01d8e/01d8e0db0a77429d5c53aaa6a9d82626de40024b" alt=""
-
1.监视 ref 定义的【基本类型】数据:直接写数据名即可,监视的是其 value 值的改变。调用这个函数可以终止监听,比如函数名stopwatch()
data:image/s3,"s3://crabby-images/c36cc/c36cc6a80c5d06406b65bd9af54fae83904a716c" alt=""
-
2.监视对象:监视ref对象。
不管是ref还是reactive监视一整个对象时而不是某个非对象属性,则只要外围对象没有生成新的对象赋值,则newValue、oldValue都是指向新值。虽然对象内属性改动变化了,但是对象还是那个对象,对象地址值不变。
data:image/s3,"s3://crabby-images/64dc3/64dc3101891223418ff40accaa177a323fbe4b08" alt=""
data:image/s3,"s3://crabby-images/d7f73/d7f7330e0c92feb852100560937a01e91639d189" alt=""
-
3.监视对象:监视reactive对象。
reactive只能定义对象,所以只能监视整个对象,这个模式默认开启深度监视,且无法关闭。深度监视开启后,就可以监视对象内的某个任意属性变化。
data:image/s3,"s3://crabby-images/ddbbc/ddbbc3a506136d43cbce85b6ba0723d9270a348c" alt=""
-
4.侦听对象内的某个特定属性,其他属性不监视
对象子属性:基本类型属性
data:image/s3,"s3://crabby-images/2ddb6/2ddb6d59490d96225e7aaf2c97549866a8295fad" alt=""
对象子属性:对象类型属性。手动开启深度监视。
data:image/s3,"s3://crabby-images/a48bf/a48bf3078dc46d69848feb9763fc1604a159b56a" alt=""
data:image/s3,"s3://crabby-images/5b280/5b280b9d3b60c9b52ca0791af87d19bd8c3bf3f1" alt=""
-
5.侦听多个属性,写成数组形式
data:image/s3,"s3://crabby-images/bbdd9/bbdd93810f515bcc26d77259d08ae9cc745dd22f" alt=""
七、watchEffect属性
data:image/s3,"s3://crabby-images/c9919/c991969a3b49ac566f88faa467c244a38ed8d73a" alt=""
data:image/s3,"s3://crabby-images/6b5ff/6b5ffd244b5f62d9cad4fad0697be0ae64a976aa" alt=""
八、标签节点的ref属性
data:image/s3,"s3://crabby-images/d9e3e/d9e3e34052f91cf71c3d548c5e296519cfa9bd90" alt=""
data:image/s3,"s3://crabby-images/1cf56/1cf56ed842199547aa182b38995d001edde43a16" alt=""
九、组件传参:defineProps属性
defineProps接收组件传递的参数。defineXXX都不需要直接引用,是属于宏函数。
data:image/s3,"s3://crabby-images/2f85e/2f85e8a860eb2425abbebcf7d15b0af341fd8d36" alt=""
十、Vue3生命周期
- setup函数替代了Vue2中beforeCreate、created生命周期。
-
程序解析到子组件时,子组件的可执行的生命周期全部经历后,才会继续执行父组件剩余生命周期。
image.png
十一、Vue3的Hooks
Hooks的使用替换了Vue2中mixin的使用,是实现组合式API开发的关键。可以在创建的Hooks的useXXX文件函数里面封装你的代码,也可以使用生命周期钩子函数。合理的封装你的功能模块。
data:image/s3,"s3://crabby-images/2fd20/2fd20d13095214058978029c3119ec0eb7374b04" alt=""
data:image/s3,"s3://crabby-images/b925f/b925f57c60852e810d83f551a15f9763952cf7ac" alt=""
data:image/s3,"s3://crabby-images/a72b0/a72b00fcc42a86ba12c07f2992fd795290cbc5b8" alt=""
十二、Vue3的路由
-
Vue3和Vue2路由使用基本相同。
data:image/s3,"s3://crabby-images/9ca60/9ca6005d77b0a559c0c5a7e1dfe50b3d5f436847" alt=""
-
路由器工作模式
data:image/s3,"s3://crabby-images/5a7f3/5a7f39fd77cb1afd7f679525137639c0c826e8f3" alt=""
data:image/s3,"s3://crabby-images/40142/4014238d082b375b27d2f12b6461908750e2e708" alt=""
data:image/s3,"s3://crabby-images/f50ac/f50ac614feba2461bf1d6beb75e4c5714565bdc5" alt=""
data:image/s3,"s3://crabby-images/00fa1/00fa184399d3594d574ddddc3a566c98a8142ca3" alt=""
-
路由传参
1.query传参,两种写法方式。字符串写法和对象写法。
data:image/s3,"s3://crabby-images/6b513/6b513d8c6d2b286c69272faa2b72451a75aa04c3" alt=""
2.params传参,也是有两种写法方式。字符串写法和对象写法。但是注意这时候,只能使用name路由路径写法。注意,这种写法不可以传递对象和数组。
data:image/s3,"s3://crabby-images/71705/71705be36533662a041d5dc7563e8420bd887c8a" alt=""
路由配置props:true,所有路由器接收参数都转换为组件属性
data:image/s3,"s3://crabby-images/1dde1/1dde1e8b8b61d4e9d91c549c61f3a9f5d29a2757" alt=""
路由配置props其他写法
data:image/s3,"s3://crabby-images/e28ca/e28ca56df701a216e2a1a1b529330766c340c5b8" alt=""
3.编程式路由器userRouter使用,RouterLink标签可以用的api属性userRouter也可以用
data:image/s3,"s3://crabby-images/93446/934466a31ca7cfcb0f2e30e478a6f646b9ac68f7" alt=""
data:image/s3,"s3://crabby-images/82b74/82b74756b2138bcbe7416ccaca83e6d72f5d7ff3" alt=""
4.重定向路由导航redirect使用。可用于程序初始化页面显示的组件内容。
data:image/s3,"s3://crabby-images/12b6f/12b6f2e8a841bb713024413f0513a1b006402ff7" alt=""
十三、Vuex状态管理升级为Vue3的Pinia
-
下载、安装、初始化
image.png
npm i pinia 安装下载
data:image/s3,"s3://crabby-images/976d9/976d980766b3c99aa0ee316381f60cbdd0286cbe" alt=""
-
存储和读取数据
image.png
data:image/s3,"s3://crabby-images/fd5be/fd5be1202731430d02ed4b786fd712f0333b116e" alt=""
data:image/s3,"s3://crabby-images/81a4c/81a4cddcbb007f71f86f2b1dfbd0f9a428a98165" alt=""
- pinia内容值修改的方式。修改就是vuex里的actions+mutations(相当于setters)。
// 数据
let select=ref(1)// 用户选择的数字
// 方法
function xiugai(){
// 第一种对源数据直接修改方式,直接操作三次
countstore.sum += 1
countstore.school= '黑马培训'
countstore.address= '深圳'
// 第二种patch修改方式,一次数据操作
countstore.$patch(
{
sum:888,
school:'尚硅谷,
address:'北京
})
// 第三种actions修改方式,抽离共同修改,复用多
countstore.increment(select.value)
}
data:image/s3,"s3://crabby-images/f2de1/f2de16e239ad3235ecffc571f1afe91138c63768" alt=""
-
pinia的storeToRefs响应式数据使用。storeToRefs只会关注sotre中数据,不会对方法进行ref包裹。
image.png -
pinia的getters
image.png
data:image/s3,"s3://crabby-images/840af/840af9dcc5203ff753a6a344e74ef2504536511a" alt=""
-
pinia订阅监听数据变化。在组件使用到的地方订阅。
image.png -
pinia选项式写法和组合式写法
选项式写法
data:image/s3,"s3://crabby-images/b4f69/b4f698595fc5e4008110840de4552be776317f42" alt=""
十四、组件间通信方式
-
1.props传参方式通信(使用频率高)
image.png
data:image/s3,"s3://crabby-images/b0f47/b0f47e703e1122bb172f50e3f4f240357ac79e88" alt=""
-
2.emit自定义事件通信(使用频率高)
image.png -
3.mitt全局事件通信(使用频率高)。类似vue2全局事件总线。mitt可以实现任意组件间通信。
注意在onUnmounted组件销毁时卸载绑定的事件,调用emitter.off('事件名')解绑,节省资源。
image.png
-
4.v-model通信。
实现双向绑定的原理
image.png
封装一个双向绑定username值的v-model组件功能,实现父与子组件(input类型)的双向通信。在子组件呈现父组件传递过来的modelValue参数,并且给父组件发送自定义事件,将值回传赋值给username。
-
5.attrs实现爷爷组件向孙子组件通信。儿子组件需要设置attrs绑定。
image.png
- 6.
parent实现组件通信。
image.png
-
7.provide与inject实现组件通信。provide祖向孙通信,inject接收注册。
image.png
十四、插槽slot。也是组件件通信的一种方式,多用于ui构建。
-
默认插槽。名称默认是<slot name='default' >
-
具名插槽。v-slot='abc'可以简写为#abc
-
作用域插槽。
数据在子那边,但根据数据生成的结构,却由父亲决定。
如:压岁钱在孩子那,但根据压岁钱买的东西,却由父亲决定。
十五、响应式数据其他api补充
-
浅层次响应式:浅层次双向绑定响应式shallowRef、shallowReactive
-
单向只读响应式readOnly(深层次)、shallowReadOnly(浅层次)
-
toRaw与martRaw
toRaw对响应式数据剥壳,得到无响应式功能的原始数据对象,多用于传参的时候
markRaw永久性的设置为原始数据对象
-
自定义Ref,customRef。
实现Ref响应式功能
customRef:在原生Ref功能上加上自己的处理逻辑
如实现一个延时更新的Ref,封装成hooks
十六、Teleport使用
data:image/s3,"s3://crabby-images/fc35d/fc35dbb8446daa691d718704098e8f08cc511634" alt=""
喜欢的朋友记得点赞、收藏、关注哦!!!