vue3基础入门以及常用api使用

setup

setup 的返回值可以是函数

data(){
return {
a:'111',
c:this.name
}
},
setup(){
let name = '1111'
return ()=> '哈哈哈'
}//结果页面就是会显示 哈哈哈

setup和 OptionsAPI关系
data能和setup能同时存在,但不建议
data能读到setup里边的数据 setup是最早的生命周期 setup比data执行的要早

setup语法糖

想要组件name 和setup用一个script 可以用一个插件 npm i vite-plugin-vue-setup-extend -D

vite.config.js 文件中 引入

import VueSetupExtend from 'vite-plugin-vue-setup-extend'
plugins:[vue(),VueSetupExtend()
]
//然后在script写即可
<script setup name='Person234'>

ref

ref 实现对象类型响应式 深层次也是借助于reactive实现的

reactive

reactive重新分配一个对象,会失去响应式,用 Object.assign(car,{brand:‘品牌’}) 分配对象 car是个reactive对象

ref定义对象,要是重新分配对象可以直接car.value = {}

如果定义基本类型响应式数据,用ref
定义层级不深的对象数据,ref和reactive都行
定义层级深的,建议用reactive

toRefs和toRef

toRef是就是把对象类型中的每一个参数单拎出来变成ref
let age = toRef(person,‘age’)//把person里边的age解构出来
let { age,name} = person
let { age,name} = toRefs(person)

computed

有缓存

//只读
const aa = computed(()=>{
return '1111'
})let firstName = ref('zhang')
let lastName  = ref('san')
//可读可写
let fullNmae = computed({
get(){return firstName + '_'+ lastName
},
set(val){//val就是fullName.value赋值拿到的,这里是'12345'console.log('set',val)let [str1,str2] = val.split('_')firstName.value = str1lastName.value = str2}
})
这时候就可以 fullNmae.value = 'li-si'//得有set(){}

watch

vue3中watch只能监视以下四种数据:
1、ref定义的数据
2、reactive定义的数据
3、函数返回的一个值(getter函数->能返回一个值的函数)
4、一个包含上述内容的数组

//监听基础类型的ref,不需要.value
let count = ref(0)
watch(count,(newVal,oldVal)=>{console.log(newVal,oldVal)
})
//情况一:监听对象类型的ref,他只是监听对象的地址值,
let person = ref({
age:12,
name:'张三'
})
watch(person,(newVal,oldVal)=>{
console.log(newVal,oldVal)
//更改person 属性 person.value.name='11' 并不会打印
//更改person整个值才会走watch  person.value = { name:'11',age:10}
})
//-----------------------------------------------------------
//情况二:若想监听ref对象中的属性变化,使用deep:true
function changeName() {person.value.name = '李四'
}
function changeAge() {person.value.age = 20
}
function changePerson() {person.value = {name: '王五',age: 20}
}
watch(person,(newVal,oldVal)=>{console.log(newVal,oldVal)
},
{deep:true
}
)
//会出现情况是:
//单纯更改其中参数,监听打印的是Proxy(Object) {name: '李四', age: 20} Proxy(Object) {name: '李四', age: 20}
//可以假设成person的{name:xx,age:xx}是一个房子,改其中的参数只是改房子里边的东西,房子没变,所以每次监听房子新值和旧值一样
//更改整个person参数才会是Proxy(Object) {name: '王五', age: 20} Proxy(Object) {name: '李四', age: 20}
//---------------------------------------------------------
//情况三:监视reactive定义的对象数据,更改参数和整个对象都会受到监视,默认是开启深度监视的,而且用deep:false是不可以的
//但是打印新值和旧值是一样的,因为房子没变
let obj = reactive({a:{b:{c: 10}}
})
function changeTest() {obj.a.b.c = 20
}
watch(obj,(newVal,oldVal)=>{console.log('obj变化了',newVal,oldVal)
},
{deep:true
}
)
//-------------------------------------------------------------------------
//情况四:监视ref或reactive定义的【对象类型】数据中的某个属性,注意点如下:
//1、若该属性值不是【对象类型】,需要写成函数形式
//2、若该属性值依然是对象类型,可直接编,也可写成函数,不过建议写成函数
let person = reactive({name:'张三',car:{c1:'大众',c2:'比亚迪',}
})
function changeName() {person.name += '~'
}
//监视的reactive对象中属性不是对象类型,得用函数
watch(()=> person.name,(newVal,oldVal)=>{console.log('person.name变化了',newVal,oldVal)
}
)
//每次person.name变化watch都监听,且新值和旧值不一样
//监听reactive对象中属性为对象时建议也是函数
//这时候直接修改person.car = { c1:'雅迪'c2:'爱玛'}也能监听到
watch(()=> person.car,(newVal,oldVal)=>{console.log('person.name变化了',newVal,oldVal)
},{
deep:true
}
)
//-------下面这样修改car里边参数能监听比如更改c1和c2,但是直接修改car不会监听到,可以这么写但不建议----
watch(person.car,(newVal,oldVal)=>{console.log('person.name变化了',newVal,oldVal)
})
//监视上述的多个数据,(把他们放到同一个数组里)
watch([()=>person.name,()=>person.car.c1],(newVal,oldVal)=>{console.log('person.name变化了',newVal,oldVal)
})
//打印值也是数组['张三~','奔驰']

watchEffect

相比于watch,watchEffect不用特意指出监听的是哪个参数,且会立即运行一个函数,同时响应的追踪其依赖
比如同时监听多个参数时相对来说好一点,因为不用标注监听哪个参数

<script setup>
import { watchEffevt } from 'vue'
const count = ref(1)
watchEffect(()=>{
console.log(count.value)//当count变化时就会打印
})
</script>

标签的ref

 <h2 ref="title2">获取元素</h2>
import {ref} from 'vue'
//创建一个ref对象,用于存储ref标记的内容 创建名称要和元素ref=""中的名称一样
let title2 = ref()
//获取值用title2.value,即使两个vue文件中ref名称一样也不会冲突//给组件加ref
<Person ref='person'/>
let person = ref()
//如何拿到子组件东西,需要子组件用defineExpose
//Person里边
import { defineExpose } from 'vue'//其实也不用引入
let a = ref(0)
let b = ref(1)
defineExpose({a,b})

props

//父<PersonInfo msg="aaa" />
//可能最新vue3不需要引入defineProps defineEmit 可以直接使用
import { defineProps } from 'vue'
//接受+同时将数据保存起来
let props = defineProps({msg: String
})
console.log(props.msg)//aaa
//情况一:只接受
defineProps(['msg'])
//情况二:接受+限制类型 Persons是自定义的type
defineProps<{list: Persons}>()
//情况三:接受list+限制类型+限制必要性+指定默认值
interface PersonInter {
name:string,
id:string,
age:number
}
type Persons = Array<PersonInter>import { withDefaults } from 'vue'
const props = withDefaults(defineProps<Persons>(), {name: '',id: '',age: 10}} 
//给数组设置默认也需要加上箭头函数
const props = withDefaults(defineProps<{list?:Persons}>(), {list:()=>[{id:'123',name:'张三',age:10}]})
//情况四:使用箭头函数声明
const props = defineProps({List: {type: Array,required: true,default: () => [{ name: '文件1' }, { name: '文件2' }]}

provide和inject

      **方便props多层级透传**

有一些多层级嵌套的组件,形成了一棵巨大的组件树,而某个深层的子组件需要一个较远的祖先组件中的部分数据。在这种情况下,如果仅使用 props 则必须将其沿着组件链逐级传递下去,这样使用也很麻烦,这时候就可以使用provide和inject

//祖先组件中使用provide
<script setup>
import { provide } from 'vue'
provide(/* 注入名 */ 'age', /* 值 */ '11')
//例子
provide('age', '11')
</script>
//子组件中用inject使用父组件提供的值
<script setup>
import { inject } from 'vue'
const age = inject('age')
console.log('age', age)  //输出 11
</script>

生命周期

vue2和vue3对比
在这里插入图片描述
子组件先挂载完毕(onMounted),父再挂载完毕

自定义hooks

多个页面需要同一个功能就可以使用hooks,而且hooks里边能使用钩子例如onMounted等,还能用computed
useSum.ts

import { ref } from 'vue'
export function useSum() {const sum = ref(0)function add() {sum.value += 1}return { sum, add }
}
import { useSum } from 'xxx'
const { sum, add } = useSum()

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

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

相关文章

【二刷hot-100】day2

目录 1.无重复字符的最长子串 2.找到字符串中所有字母异位词 3.和为 K 的子数组 4.滑动窗口最大值 1.无重复字符的最长子串 class Solution {public int lengthOfLongestSubstring(String s) {Map<Character,Integer> dict new HashMap<>();int ret0;int i-1;for…

使用 GoZero 框架实现一个简单的course课程class系统

使用 GoZero 框架实现一个简单的课程增删改查&#xff08;CRUD&#xff09;功能需要进行以下步骤&#xff1a;设置 GoZero 项目、定义数据模型、创建相应的 API 接口以及实现 CRUD 操作。下面是一个示例代码&#xff0c;包括基本的课程管理功能。 ### 1. 安装 GoZero 首先&…

基于SSM党务政务服务热线管理系统的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;部门管理&#xff0c;办事信息管理&#xff0c;信息记录管理&#xff0c;系统管理 前台账号功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;部门&#xff0c;信息…

十月编程语言排行榜~

前言&#xff1a;TIOBE编程语言排行榜通过分析全球开发者的活动、代码搜索和问答社区的流量&#xff0c;提供了编程语言受欢迎度的动态图景。该指数是技术趋势的风向标&#xff0c;揭示了哪些编程语言在技术领域占据主导地位&#xff0c;哪些语言正在快速崛起或逐渐衰退。 ✨✨…

骨传导耳机哪款比较值得入手?五款热门机型实测内容分享!

在贴吧、论坛、知乎等社区网站上&#xff0c;大家可能经常看到用户吐槽、讨论骨传导耳机哪种好等话题。很多人反映&#xff0c;由于使用了不适合的骨传导耳机&#xff0c;出现了听力不适、佩戴不稳等诸多问题。作为一名有着丰富经验的数码测评师&#xff0c;我对此问题非常关注…

考研数据结构——C语言实现二叉树前,中,后序非递归遍历

定义二叉树节点&#xff08;BTree&#xff09;&#xff1a; ElemType value&#xff1a;存储节点的值。struct BTree* LeftChild&#xff1a;指向左子节点的指针。struct BTree* RightChild&#xff1a;指向右子节点的指针。 节点访问函数&#xff08;visit&#xff09;&#x…

Linux SSH无密码使用私钥远程登录连接详细配置流程

文章目录 前言1. Linux 生成SSH秘钥对2. 修改SSH服务配置文件3. 客户端秘钥文件设置4. 本地SSH私钥连接测试5. Linux安装Cpolar工具6. 配置SSHTCP公网地址7. 远程SSH私钥连接测试8. 固定SSH公网地址9. 固定SSH地址测试 前言 本文将详细介绍如何将Linux SSH服务与cpolar相结合&…

【算法】深入理解布隆过滤器

1. 什么是布隆过滤器&#xff1f; 布隆过滤器&#xff08;Bloom Filter&#xff09;是一种空间效率极高的概率型数据结构&#xff0c;用于检测某个元素是否在一个集合中。与常见的数据结构如哈希表不同&#xff0c;布隆过滤器无法删除元素&#xff0c;并且会存在一定的误判率&…

实操部署amis-admin

当需要做一个web服务的时候&#xff0c;前端的实现很令我头疼。搜了一圈前端低代码框架后&#xff0c;注意到百度贡献的amis&#xff0c;通过json来写前端&#xff0c;很酷啊。不得不说&#xff0c;一个好的demo项目&#xff0c;真的能让人迅速进入状态&#xff0c;比直接看文档…

c++常用库函数

一.sort排序 快排的改进算法&#xff0c;评价复杂度为(nlogn). 1.用法 sort(起始地址&#xff0c;结束地址下一位&#xff0c;*比较函数) [起始地址&#xff0c;结束地址) (左开右闭) #include<bits/stdc.h> using namespace std; int main() {//sortvector<int&g…

基础sql

在执行删除操作之前&#xff0c;建议先运行一个 SELECT 查询来确认你要删除的记录。这可以帮助你避免误删数据。 删除字段id默认值为空字符串的所有数据 delete from users where id ; 删除字段id默认值为null的所有数据 delete from users where id is null; 删除字段upd…

msvcp140.dll重新安装的解决方法,msvcp140.dll丢失快速修复教程

msvcp140.dll丢失的问题是许多电脑用户经常遇到的问题。msvcp140.dll是Microsoft Visual C Redistributable Package的一部分&#xff0c;这个软件包包含了许多Windows系统运行所需的重要文件。当msvcp140.dll丢失时&#xff0c;可能会导致许多应用程序无法正常运行&#xff0c…

基于华为云智慧生活生态链设计的智能鱼缸

一. 引言 1.1 项目背景 随着智能家居技术的发展和人们对高品质生活的追求日益增长&#xff0c;智能鱼缸作为一种结合了科技与自然美的家居装饰品&#xff0c;正逐渐成为智能家居领域的新宠。本项目旨在设计一款基于华为云智慧生活生态链的智能鱼缸&#xff0c;它不仅能够提供…

初阶数据结构【2】--顺序表(详细且通俗易懂,不看一下吗?)

本章概述 线性表顺序表顺序表问题与思考彩蛋时刻&#xff01;&#xff01;&#xff01; 线性表 概念&#xff1a;一些在逻辑上成线性关系的数据结构的集合。线性表在逻辑上一定成线性结构&#xff0c;在物理层面上不一定成线性结构。常见的线性表&#xff1a;顺序表&#xff0…

学习文档(6)

Redis数据类型 Redis 常用的数据类型有哪些&#xff1f; Redis 中比较常见的数据类型有下面这些&#xff1a; 5 种基础数据类型&#xff1a;String&#xff08;字符串&#xff09;、List&#xff08;列表&#xff09;、Set&#xff08;集合&#xff09;、Hash&#xff08;散…

影楼即将倒闭!!!!stable diffusion comfyui制作:AI人像摄影专业工作流

最近我们在学习ComfyUI&#xff0c;并用它搭建的摄影写真工作流&#xff0c;只需几张照片即可生成可交付的艺术写真照。 AI写真有以下好处&#xff1a; 创意无限&#xff1a;AI写真可以创造出超越现实的场景和效果&#xff0c;为用户提供更多的创意空间。用户可以通过简单的输…

MySQL 读写分离

优质博文&#xff1a;IT-BLOG-CN 一、背景 随着机票业务不断增长&#xff0c;订单库的读性能遇到了挑战&#xff0c;因此对订单库进行读写分离操作。主要目的是提高数据库的并发性能和可扩展性。当系统的所有写操作效率尚可&#xff0c;读数据请求效率较低时&#xff0c;比如…

快速解决Windows端口被占用

检查占用的端口号,显示9210端口被占用 使用运行打开cmd&#xff0c;直接输入如下命令 netstat -ano | find "9210"可以看到 9210端口执行的进程是PID为26836 知道PID后打开电脑的任务管理器-详细信息,找到PID是26836的进程,可以看到是QQ,关掉就解决了

微软开源项目 Detours 详细介绍与使用实例分享

目录 1、Detours概述 2、Detours功能特性 3、Detours工作原理 4、Detours应用场景 5、Detours兼容性 6、Detours具体使用方法 7、Detours使用实例 - 使用Detours拦截系统库中的UnhandledExceptionFilter接口,实现对程序异常的拦截 C++软件异常排查从入门到精通系列教程…

路由通信 的 VLAN技术

一、VLAN基础 虚拟局域网&#xff08;Virtual Local Area Network&#xff0c;VLAN&#xff09; 根据管理功能、组织机构或应用类型对交换局域网进行分段而形成的逻辑网络。 交换机最多支持4094个VLAN&#xff0c;其中默认管理VLAN是VLAN1&#xff0c;不能创建&#xff0c;也…