Vue3【进阶】

简介

https://cn.vuejs.org/guide/introduction.html

创建vue3工程

【基于 vue-cli创建】

基本和vue-cli的过程类似,只是选择的时候用vue3创建

【基于vite创建】【推荐】

【官网】https://vitejs.cn/ 【可以先去学一下webpack】
image.png
image.png

步骤 【https://cn.vitejs.dev/guide/】

npm create vue@latest
pnpm create vue

你还可以通过附加的命令行选项直接指定项目名称和你想要使用的模板。例如,要构建一个 Vite + Vue 项目,运行:
bash

# npm 7+, extra double-dash is needed:
npm create vite@latest my-vue-app -- --template vue# yarn
yarn create vite my-vue-app --template vue# pnpm
pnpm create vite my-vue-app --template vue# bun
bun create vite my-vue-app --template vue

查看 create-vite 以获取每个模板的更多细节:vanilla,vanilla-ts, vue, vue-ts,react,react-ts,react-swc,react-swc-ts,preact,preact-ts,lit,lit-ts,svelte,svelte-ts,solid,solid-ts,qwik,qwik-ts。

命令行创建

image.png
image.png

小结

image.png

VUE3核心语法

【optionsAPI】和【compositionAPI】->【vue2】和【vue3】

image.png
image.png
image.png
image.png

拉开序幕的【setup】

image.png

  • 新的配置项
  • setup语法糖出现时机在beforecreated之前
  • setup的返回值也是一个渲染函数

【面试题】setup和vue2中的data、method有什么区别?

  • 可以同时存在
  • setup执行的比data的早(data可以拿到setup中的值,但是反过来拿不到)

Setup语法糖

之前的写法
image.png
缺点是:每次都要返回数据和方法
语法糖写法
image.png
不需要返回,setup自动给你返回;只关注数据和方法
因为最新的语法糖省去了name,则利用插件npm i vite-plugin-vue-setup-extend -D来命名
image.png
image.png
一般其实和文件名一样可以不写

ref_可以实现【基本类型】响应式数据 【让数据动起来】

vue2->都放在data中,就是响应式了
vue3->ref 和 reative 此ref不是vue2中的ref
image.png

  • 什么时候需要value和什么时候不需要value是需要注意的点
  • 模块中不需要。JS中操作需要!

作用:
image.png

reactive_创建【对象类型】【只能定义】响应式数据

image.png
image.png

ref_可以实现【对象类型】响应式数据 【让数据动起来】

image.png

需要注意的是:

  • 使用ref的时候必须加上.value去拿到值
  • ref的实现也是基于reactive实现的(底层逻辑)
  • ref既可以定义基本类型也可以对象类型

【ref对比reactive】

image.png

  • 可以用volar插件【目前是官方vue插件】自动添加.value

在设置中进行设置-勾上即可
image.png

toRefs 和 toRef

image.png

<template><h1>hello</h1><h1>姓名:{{ name }}</h1><h1>年龄:{{ age}}</h1><button @click="changeName">修改名字</button><button @click="changeAge">修改年龄</button></template><script setup lang="ts">import { reactive,toRefs } from 'vue';let person = reactive({name: 'John',age:22})// toRefs 就是将reactive中的数据都取出来 数据还是具备响应式let {name, age} = toRefs(person)const changeName = () =>{name.value = 'lisi'}const changeAge = () =>{age.value += 1}
</script><style></style>

computed属性【是有缓存的】

image.png

<template>姓:<input type="text" v-model="names"><br>名:<input type="text" v-model="ming"><br>姓名: <h1>{{fullname}}</h1><button @click="changeFullname">修改全名</button>
</template><script setup lang="ts">
import { ref ,computed} from 'vue';let names= ref('张三')
let ming = ref('ming')// 只读的不可修改的
// let fullname =computed(()=>{
//    return names.value +  ming.value.slice(0,1).toUpperCase() + ming.value.slice(1)
// })
// 这样可读可写
let fullname =computed({get(){return names.value +  ming.value.slice(0,1).toUpperCase() + ming.value.slice(1)},set(vals){const x = vals.split('-')names.value = x[0]ming.value = x[1]console.log(x);},
})
let changeFullname  = ()=>{console.log(fullname.value);fullname.value = 'li-si'}
</script><style></style>

watch监视数据的变化

image.png

情况一【常用】:

image.png

<template><div class="person"><h1>情况一</h1><h1>sum:{{ sum }}</h1><button @click="changeName">点我sum+1</button></div>
</template><script setup lang="ts">
import {ref,watch} from 'vue'
let sum = ref(100)let changeName = ()=>{sum.value += 100
}
const stopWatch =  watch(sum,(newValue,oldValue)=>{console.log(newValue,oldValue);if(newValue>1000){stopWatch()}
})
</script><style></style>

情况二:

image.png
image.png

<template><div class="person"><h1>姓名:{{person.name }}</h1><h2>年龄:{{person.age}}</h2><button @click="changename">修改年龄</button><button @click="changeperson">修改person</button></div>
</template><script lang="ts" setup>
import {ref,watch} from 'vue'let person = ref({name:"zhangsan",age:22,})const changename = () =>{person.value.age += 1;}const changeperson = () =>{// 如果是recative 就要用object.assginperson.value = {name:"zha33ngsan", age:2342}}watch(person,(newValue,oldValue)=>{console.log(newValue,oldValue);},{deep:true,immediate:true})</script><style>.person{background-color: skyblue;box-shadow: 0 0 10px;border-radius: 10px;padding: 10px;}
</style>

情况三:

image.png
看一个案例:ref 和 reactive 对象赋值的区别
image.png

<template><div class="person"><h1>姓名:{{person.name }}</h1><h2>年龄:{{person.age}}</h2><button @click="changename">修改年龄</button><button @click="changeperson">修改person</button></div>
</template><script lang="ts" setup>
import {ref,watch,reactive} from 'vue'let person = reactive({name:"zhangsan",age:22,})const changename = () =>{person.age += 1;}const changeperson = () =>{// 如果是recative 就要用object.assginObject.assign(person,{name:"zha33ngsan", age:2342})}watch(person,(newValue,oldValue)=>{console.log(newValue,oldValue);})</script><style>.person{background-color: skyblue;box-shadow: 0 0 10px;border-radius: 10px;padding: 10px;}
</style>

情况四【常用】【函数式】:

image.png
image.png
结论: 监视的要是对象里面的属性,最好写成函数,注意:若是监视的是地址值,需要关注对象内部。需要开启手动深度监视

<template><div class="person"><h1>姓名:{{person.name }}</h1><h2>年龄:{{person.age}}</h2><h2>汽车:{{person.car.car1}}-{{ person.car.car2 }}</h2><button @click="changename">修改年龄</button><button @click="changeperson">修改person</button><button @click="changeCar1">修改car1</button><button @click="changeCar2">修改car2</button><button @click="changeAll">修改全部</button></div>
</template><script lang="ts" setup>
import {ref,watch,reactive} from 'vue'let person = reactive({name:"zhangsan",age:22,car:{car1:'hello1',car2:'hello2'}})const changename = () =>{person.age += 1;}const changeperson = () =>{// 如果是recative 就要用object.assginObject.assign(person,{name:"zha33ngsan", age:2342})}const changeCar1 = ()=>{person.car.car1 = 'world1'}const changeCar2 = ()=>{person.car.car2 = 'world2'}const changeAll = ()=>{person.car = {car1:'hello221', car2:'hello241'}}watch(()=>{return person.age},(newValue,oldValue)=>{console.log(newValue,oldValue);})watch(()=>person.car,(newValue,oldValue)=>{console.log(newValue,oldValue);},{deep:true})
</script><style>.person{background-color: skyblue;box-shadow: 0 0 10px;border-radius: 10px;padding: 10px;}
</style>

情况五:

监视上述的多个数据【多个函数】
image.png

    watch([()=>person.name,()=>person.car.car1],(newValue,oldValue)=>{console.log(newValue,oldValue);},{deep:true})

【多写项目-练习】

watchEffect

image.png
image.png

标签中ref属性

image.png
image.png

回顾TS中的接口_泛型_自定义类型

image.png

Props的使用

vue2【父子之间的通信】
image.png
vue3通信
image.png
image.png
注意点:【区别一下:的绑定和 ref的区别】
image.png
【父子之间的传值的多种方式】
image.png
【注意:宏函数不用引入,例如defineProps】

理解生命周期【组件的一生】

image.png
创建、挂载、更新、销毁【每个时期都调用特定的函数】
created 、 mounted 、updated 、destoyed
叫法:生命周期、生命周期函数、生命周期钩子

vue2的生命周期

创建、(前与后)(beforeCreate|Created)
挂载、(前与后)(beforeMount|Mounted)
更新、(前与后)(beforeUpdate|updated)
销毁、(前与后)(beforeDestory|destoryed)

vue3的生命周期

创建、setup ----------------------------> (前与后)(beforeCreate|Created)
挂载、onBeforeMount|onMounted—>(前与后)(beforeMount|Mounted)
更新、onBeforeUpdate|onUpdated—>(前与后)(beforeUpdate|updated)
卸载、onBeforeUnmount|onUnmounted---->(前与后)(beforeDestory|destoryed)
image.png

自定义hooks【mixin】【重】

image.png

路由

image.png
image.png
image.png

两个注意点

image.png
路由组件:pages/views
一般组件:components
image.png

to的两种写法

image.png

路由器工作模式

【history 和 hash模式】
image.png
image.png

命名路由

image.png
image.png

嵌套路由

image.png
image.png

路由_query参数

image.png

路由_params参数

image.png

  • 必须为name
  • 参数如果可传可不传则添加?在占位的地方
  • 参数不能为数组和对象

image.png

路由的Props配置

image.png
image.png
image.png
image.png

【注意】
  • 一般组件和路由组件传参的区别

路由的_replace属性

  • push【默认】
  • replace【替换】

image.png

【编程式导航】

image.png

出了routerlink进行跳转还有编程式路由导航

image.png

  • 什么时候进行编程式导航
    • 需要再某个条件下跳转

image.png

路由重定向

image.png

Pinia【对比VUE2中vuex】【集中式状态数据管理】

【redux vuex pinia】
image.png
是vue的最新的状态管理工具,是vuex的替代品
image.png

手动添加pinia

官网:https://pinia.vuejs.org/zh/introduction.html

  1. 使用vite创建一个新的vue3项目
  2. 安装pinia到项目中

用vite安装时注意node的版本

案例

image.png
image.png
lovetalk.vue

<template><div class="lovetalk"><button @click="getLoveTalk">hello</button><ul><li v-for="item in newsList" :key="item.id">{{ item.title }}</li></ul></div>
</template><script lang="ts" setup>
import { reactive } from 'vue';
import axios from 'axios';
import { nanoid } from 'nanoid';
const newsList = reactive([{ id: '12423421', title: 'hel123' },{ id: '1224231', title: 'h424el123' },{ id: '1242341', title: 'he4243l123' },
]);
async function getLoveTalk() {// 下面的写法:连续解构赋值 + 重命名let {data: { content:title },} = await axios.get('https://api.uomg.com/api/rand.qinghua?format=json');//    nanoid 可以随机生成IDlet obj = { id: nanoid(),title};console.log(obj);newsList.unshift(obj);
}
</script><style>
.lovetalk {background-color: skyblue;box-shadow: 0 0 10px;border: 1px solid black;
}
</style>

count.vue

<template><div class="count"><h2>当前求和为:{{sum}}</h2><select v-model.number="n"><option value="1">1</option><option value="2">2</option><option value="3">3</option></select><button @click="add">加</button><button @click="minus">减 </button></div>
</template><script setup lang="ts">
import {ref} from 'vue'
let sum = ref(1)
let n = ref(1)
function add(){sum.value += n.value
}
function minus(){sum.value -= n.value
}
</script><style>
.count {background-color: skyblue;box-shadow: 0 0 10px;border: 1px solid black;
}
</style>

【注意】:引入了axios和nanoid【随机生成id】

搭建pinia环境

npm i pinia
image.png

存取读取数据

image.png
image.png

修改数据的三种方式

image.png
image.png

storeToRefs【只关注store数据】【对数据进行解构操作】

image.png

getters

image.png
对数据的加工

$subscribe

image.png
image.png

store的组合式写法【推荐】

image.png

组件通信_方式1_props 【父子】

image.png
image.png

组件通信_方式2_自定义事件【子传父】

image.png

组件通信_方式3_mitt【任意组件通信】

  • pubsub
  • $bus
  • mitt

image.png
image.png

组件通信_方式4_v-model【通常用于表单】

作用在组件和html的方式【底层】
image.png
image.png
image.png

组件通信_方式5_$atters【祖孙之间通信】【打扰了中间人】

image.png
image.png

组件通信_方式6_ r e f s − refs- refsparent【父->子|子->父】image.png

image.png

组件通信_方式7_provide_inject【提供-注入】【向后代之间通信】【零打扰】

image.png

插槽

默认插槽

image.png

具名插槽【template 中 v-solt & #】【重】【动态的摆放】

image.png
可以用【#s1 、#s2代替v-slot】

作用域插槽

image.png

总结

image.png

其他API

shallowRef 和 shallowReactive

image.png
image.png

readonly 和 shallowReadonly

image.png
image.png

roRaw 和 markRow

image.png
image.png

customRef

image.png
image.png
image.png

Teleport【转移】

image.png

Suspense

image.png

全局api到应用对象

image.png

其他【非兼容性改变】

image.png

面试题:vue3相比vue2做了哪些改变?

https://v3-migration.vuejs.org/zh/breaking-changes/
image.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/798474.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

#QT项目实战(天气预报)

1.IDE&#xff1a;QTCreator 2.实验&#xff1a; 3.记录&#xff1a; &#xff08;1&#xff09;调用API的Url a.调用API获取IP whois.pconline.com.cn/ipJson.jsp?iphttp://whois.pconline.com.cn/ipJson.jsp?ip if(window.IPCallBack) {IPCallBack({"ip":&quo…

华为海思2024春招数字芯片岗机试题(共9套)

huawei海思2024春招数字芯片岗机试题(共9套&#xff09;&#xff08;WX:didadidadidida313&#xff0c;加我备注&#xff1a;CSDN huawei数字题目&#xff0c;谢绝白嫖哈&#xff09; 题目包含数字集成电路、System Verilog、Verilog2001、半导体制造技术、高级ASIC芯片综合、…

Java实现二叉树(上)

1.树型结构 1.1树型结构的概念 树是一种 非线性 的数据结构&#xff0c;它是由 n &#xff08; n>0 &#xff09;个有限结点组成一个具有层次关系的集合。 把它叫做树是因为它看 起来像一棵倒挂的树&#xff0c;也就是说它是根朝上&#xff0c;而叶朝下的 1.2树型结构的特点…

二 maven构建项目

一 Maven的GAVP Maven工程相对之前的工程&#xff0c;多出一组gavp属性&#xff0c;gav需要我们在创建项目的时指定&#xff0c;p有默认值&#xff0c;后期通过配置文件修改。 GAVP是指 GroupId、ArtifactId、Version、Packaging 等四个属性的缩写&#xff0c;其中前三个是必…

c++的学习之路:14、list(1)

本章讲一下如何使用list&#xff0c;代码在文章末 目录 一、list介绍 二、增 三、删 四、查和改 五、交换 六、代码 一、list介绍 首先还是看一看官方文档的介绍如下图&#xff0c;如下方五点&#xff1a; 1. list是可以在常数范围内在任意位置进行插入和删除的序列式…

element-ui result 组件源码分享

今日简单分享 result 组件的源码实现&#xff0c;主要从以下三个方面&#xff1a; 1、result 组件页面结构 2、result 组件属性 3、result 组件 slot 一、result 组件页面结构 二、result 组件属性 2.1 title 属性&#xff0c;标题&#xff0c;类型 string&#xff0c;无默…

网络基础三——初识IP协议

网络基础三 ​ 数据通过应用层、传输层将数据传输到了网络层&#xff1b; ​ 传输层协议&#xff0c;如&#xff1a;TCP协议提供可靠性策略或者高效性策略&#xff0c;UDP提供实时性策略&#xff0c;保证向下层交付的数据是符合要求的的&#xff1b;而网络层&#xff0c;如&a…

【动态规划-状态压缩dp】【蓝桥杯备考训练】:毕业旅行问题、蒙德里安的梦想、最短Hamilton路径、国际象棋、小国王【已更新完成】

目录 1、毕业旅行问题&#xff08;今日头条2019笔试题&#xff09; 2、蒙德里安的梦想&#xff08;算法竞赛进阶指南&#xff09; 3、最短Hamilton路径&#xff08;《算法竞赛进阶指南》&模板&#xff09; 4、国际象棋&#xff08;第十二届蓝桥杯省赛第二场C A组/B组&#…

Java初始——IDEA-web的启动

Tomcat 文件夹作用 bin 启动 关闭的脚本文件 conf 配置 lib 依赖的jar包 logs 日志 temp 临时文件 webapps 存放的网站 Maven 1.在javaweb中&#xff0c;需要使用大量的jar包&#xff0c;手动导入 2.Maven 架构管理工具 核心&#xff1a;约定大于配置 必须按照规则 web idea-we…

2024.4.7

1. 2列火车 #include<myhead.h>pthread_mutex_t m1; pthread_mutex_t m2;void* run(void* arg) {while(1){pthread_mutex_lock(&m1);printf("火车B进入\n");printf("A请等待\n");pthread_mutex_unlock(&m2);sleep(2);} }int main(in…

开发项目接单报价快速计算,报价量化程序

定制化开发&#xff0c;如何计算项目预算&#xff0c;是程序开发者头疼的一个问题。 项目费用谈得过低&#xff0c;就天天加班累死赚不到钱&#xff1b;谈得过高&#xff0c;会导致顾客流失&#xff0c;信誉受损。 项目费用量化可见是多么重要。 下面是一段量化的程序&#…

跟TED演讲学英文:AI isn‘t the problem — it‘s the solution by Andrew Ng

TED英文文稿 文章目录 TED英文文稿AI isnt the problem — its the solutionIntroductionVocabularyTranscriptSummary 2024年4月6日学习吴恩达的这篇演讲 AI isn’t the problem — it’s the solution Link: AI isn’t the problem — it’s the solution Speaker: Andrew …

C语言进阶课程学习记录-第21课 - 宏定义与使用分析

C语言进阶课程学习记录-第21课 - 宏定义与使用分析 宏定义的本质实验-字面量比较宏定义表达式实验-表达式有效性宏的作用域实验-作用域分析内置宏内置宏演示小结 本文学习自狄泰软件学院 唐佐林老师的 C语言进阶课程&#xff0c;图片全部来源于课程PPT&#xff0c;仅用于个人学…

人工智能 - 服务于谁?

人工智能服务于谁&#xff1f; 人工智能服务于生存&#xff0c;其最终就是服务于战争&#xff08;热战、技术战、经济战&#xff09; 反正就是为了活着而战的决策。 既然人工智能所有结果&#xff0c;来自大数据的分挖掘&#xff08;分析&#xff09;也就是数据的应用&#x…

自动驾驶中的交通标志识别原理及应用

自动驾驶中的交通标志识别原理及应用 附赠自动驾驶学习资料和量产经验&#xff1a;链接 概述 道路交通标志和标线时引导道路使用者有秩序使用道路&#xff0c;以促进道路行车安全&#xff0c;而在驾驶辅助系统中对交通标志的识别则可以不间断的为整车控制提供相应的帮助。比如…

Transformer位置编码详解

在处理自然语言时候&#xff0c;因Transformer是基于注意力机制&#xff0c;不像RNN有词位置顺序信息&#xff0c;故需要加入词的位置信息来显示的表明词的上下文关系。具体是将词经过位置编码(positional encoding)&#xff0c;然后与emb词向量求和&#xff0c;作为编码块(Enc…

CAS Server使用Maven构建以及自定义扩展使用

介绍 ​CAS&#xff08;Central Authentication Service&#xff09;中心授权/认证服务&#xff0c;是由耶鲁大学发起的一个开源项目&#xff0c;距今已有20年之久&#xff0c;功能相当丰富&#xff0c;目的在于为Web应用系统提供一种可靠且稳定的单点登录解决方案。 CAS分为…

Open CASCADE学习|在给定的TopoDS_Shape中查找与特定顶点 V 对应的TopoDS_Edge编号

enum TopAbs_ShapeEnum{TopAbs_COMPOUND,TopAbs_COMPSOLID,TopAbs_SOLID,TopAbs_SHELL,TopAbs_FACE,TopAbs_WIRE,TopAbs_EDGE,TopAbs_VERTEX,TopAbs_SHAPE}; 这段代码定义了一个名为 TopAbs_ShapeEnum 的枚举类型&#xff0c;它包含了表示不同几何形状类型的常量。这些常量通常…

目标检测——色素性皮肤病数据集

一、重要性及意义 首先&#xff0c;色素性皮肤病变是一类常见的皮肤疾病&#xff0c;其发病率有逐年增高的趋势。这些病变可能由遗传或环境因素导致黑素细胞生成异常&#xff0c;如黑色素瘤等。黑色素瘤具有极高的恶性率和致死率&#xff0c;而且恶化可能性大&#xff0c;容易…

openplc Linux 地址映射io,读写驱动数据等使用记录

1. 上一篇记录 openplc使用C语言文件读写驱动实现基本流程。 openPLC_Editor C语言编程 在mp157 arm板上调用io等使用记录_openplc c 编程-CSDN博客 2. 下面通过映射地址的方式控制io和读写驱动数据。 在runtime 环境的 hardware 硬件配置中 选择 python on Linux(PSM)&#…