关于VUE3的一些基础知识点笔记

关于VUE3的一些基础知识点笔记

VUE3

vue2与vue3的一个重要区别是vue2是选项式API(composition API)而vue3是组合式API(option API)。

组合式API就是所有逻辑都在setup函数中,使用ref、watch等函数来组织代码,而不像vue2中分别写在data、methods、watch等配置选项中。有可复用、易于维护等优点。

vue3的生命周期

与vue2对比:created钩子变成setup函数了,其他的都加了on

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Qv5xKhAR-1685463643360)(C:\Users\28132\AppData\Roaming\Typora\typora-user-images\1685460357487.png)]

用的时候需要先导入函数

如:

<template><div>生命周期函数</div>
</template>
<script setup>import { onMounted } from "vue";// 生命周期函数:组件渲染完毕onMounted(()=>{console.log('onMounted触发了')})onMounted(()=>{console.log('onMounted也触发了')})
</script>

1.setup函数

  • setup 函数是 Vue3 特有的选项,作为组合式API的起点
  • 从组件生命周期看,它在 beforeCreate 之前执行
  • 函数中 this 不是组件实例,是 undefined,所有的vue3项目中几乎没有this,都是通过函数来获取
  • 下面的例子可以先只看setup部分,15行的setup函数里面写的所有逻辑都需要用return来返回出来才可以在模板中使用
<template><div>{{ name }}num: {{ obj.num }}<br>ref: {{ refNum }}<br>refObj:{{ refObj.name }}<button @click="btn">按钮</button></div>
</template><script >
import { reactive, ref } from 'vue'
export default {setup () {// 普通对象不是双向绑定let name = "嘻嘻嘻"// reactive将里面的数据变成响应式数据 ,注意要导入,一般解决复杂数据类型转换响应式数据const obj = reactive({num: 1})// ref 定义简单数据类型和复杂数据类型为响应式数据//  ref简单数据类型const refNum = ref(1)//  ref复杂数据类型const refObj = ref({ name: 'jack' })/*** 是对象建议用reactive 其他用ref*/const btn = function () {obj.num++refNum.value++}return { name, obj, btn, refNum, refObj }},}
</script><style></style>

setup语法糖的使用来简化代码

  • 下面的写法是在script标签中写,定义的num可以直接使用
  • script setup 中的顶层变量都可以在模板使用,数据,函数,组件。
<template><div>{{ num }}</div>
</template><script lang="ts" setup>
let num = 1</script><style></style>

2. reactive函数

  • reactive 函数通常定义复杂类型的响应式数据,参数必须是对象或者数组,如果要让对象的某个元素实现响应式时比较麻烦。需要使用toRefs(后面会说)
  • reactive的响应式是深层次的,reactive方法内部是利用ES6的Proxy API来实现的,底层本质是将传入的数据转换为Proxy对象

使用步骤:

  • vue 中导出 reactive 函数
  • setup 函数中,使用 reactive 函数,传入一个普通对象,返回一个响应式数据对象
  • 最后 setup 函数返回一个对象,包含该响应式对象即可,模板中可使用
<template><div><p>姓名:{{state.name}}</p><p>年龄:{{state.age}}</p></div>
</template><script>
// 1. 导入函数
import { reactive } from "vue"; 
export default {setup() {// 2. 创建响应式数据对象const state = reactive({ name: 'sunny', age: 24 })// 3. 返回数据return { state }}
};
</script>

toRefs函数 保持响应式

  • 在使用reactive创建的响应式数据被展开或解构的时候使用toRefs保持响应式
<template><div>这是vue3的框架!<br> obj: {{ name }}{{ age }}<br> <button @click="btn"></button></div>
</template>
<script setup>
import { reactive, toRefs } from "vue";
let obj = reactive({name: 'jack',age: 1
})
// obj是reactive的响应式数据,
// 使用了解构后就不是响应式的了
// 用toRefs转换成响应式数据
const { name, age } = toRefs(obj)const btn = function () {name.value = 'rose',age.value++
}
</script>
<style></style>

3.ref 函数

3.1 ref定义数据

  • ref通常用来定义响应式数据,不限类型
  • ref响应式原理是依赖于Object.defineProperty()get()set()的。
  • ref参数一般接收简单数据类型,若ref接收对象为参数,本质上会转变为reactive方法,系统会自动根据我们给ref传入的值转换成ref(1)->reactive({value:1}) ,ref函数只能操作浅层次的数据,把基本数据类型当作自己的属性值;深层次依赖于reactive

使用步骤:

  • vue 中导出 ref 函数
  • setup 函数中,使用 ref 函数,传入普通数据(简单or复杂),返回一个响应式数据
  • 最后 setup 函数返回一个对象,包含该响应式数据即可
  • 注意:在template中访问,系统会自动添加.value;在js中需要手动.value
<template><div><p>计数器:{{ count }}<button @click="count++">累加1</button><!-- template中使用可省略.value --><button @click="increment">累加10</button></p></div>
</template><script>
// 1. 导入函数
import { ref } from "vue";
export default {setup() {// 2. 创建响应式数据对象const count = ref(0);const increment = () => {// js中使用需要.valuecount.value += 10;};// 3. 返回数据return { count, increment };},
};
</script>
  • reactive与ref该如何选择?

如果能确定数据是对象且字段名称也确定,可使用 reactive 转成响应式数据,其他一概使用 ref

ref使用起来有点麻烦呀,需要.value 增加代码量,所以确认是复杂数据类型咱就用reactive

3.2 ref 获取DOM元素

  • 元素上使用 ref属性关联响应式数据,获取DOM元素
<script setup>
import { ref } from 'vue'
const hRef = ref(null) 
//在onMounted钩子中来获取dom元素
onMounted(()=>{console.log(dom)
})</script><template><div><h1 ref="dom">我是盒子</h1></div>
</template>

3.3 ref操作组件-defineExpose

  • 组件上使用 ref属性关联响应式数据,获取组件实例
  • 使用 <script setup> 的组件是默认关闭的,组件实例使用不到顶层的数据和函数。
  • 需要配合 defineExpose 暴露给组件实例使用,暴露的响应式数据会自动解除响应式。

子组件:将数据与方法暴露出去

<template><div><h1>son</h1></div>
</template>
<script setup>// 子向父传数据
let num = 1
let str = 'son'
const handle = function () {return '123son321'
}
// 要让父组件获取数据与方法,需要用defineExpose({})将数据暴露出去,参数是对象
defineExpose({ num, str, handle })
</script>
<style></style>

父组件:使用子组件暴露出来的方法与数据

<template><div>这是父组件<Son ref="sonDom"></Son></div>
</template>
<script setup>
import Son from './components/son.vue'
import { ref, onMounted } from "vue";
// 获取子组件的数据与方法
const sonDom = ref()
onMounted(() => {console.log(sonDom.value);console.log('Son的num值:', sonDom.value.num); //1console.log('Son的str值:', sonDom.value.str); //sonconsole.log('Son的handle方法:', sonDom.value.handle()); //123son321
})
</script>
<style></style>

4. computed函数

  • 定义计算属性

大致步骤:

  • vue 中导出 computed 函数
  • setup 函数中,使用 computed 函数,传入一个函数,函数返回计算好的数据
  • 最后 setup 函数返回一个对象,包含该计算属性数据即可,然后模板内使用
<template><div>{{ total }}4111</div>
</template>
<script setup>
import { computed } from 'vue'
// 计算属性
let arr = [12, 45, 65, 32, 12]
const total = computed(() => {return arr.reduce((sum, item) => sum + item, 0)
})
console.log(total);
</script>
<style></style>

小例子:动态求和:

<template><div>{{ arr }}:{{ total }}<input v-model="num" type="text" @change="handle" placeholder="请输入数字" /></div>
</template>
<script setup>
import { computed, ref } from 'vue'
// 计算属性
let arr = ref([12, 45, 65, 32, 12])
const total = computed(() => {return arr.value.reduce((sum, item) => (sum += Number(item)), 0)
})let num = ref(0)
const handle = () => {arr.value.push(num.value)
}
// console.log(total);
</script>
<style></style>

5.watch函数

  • 使用watch函数监听数据的变化
  • watch(需要监听的数据,数据改变执行函数,配置对象) 来进行数据的侦听
  • 数据:单个数据,多个数据,函数返回对象属性,属性复杂需要开启深度监听
  • 配置对象:deep 深度监听 immediate 默认执行

见代码中的注释:

<template><div>num:{{ num }} <br>obj:{{ obj }} <br><button @click="btn">点我加1</button></div>
</template>
<script setup>
import { ref, reactive, watch } from 'vue'
let num = ref(0)
const btn = function () {return num.value++, obj.id++
}
let obj = reactive({ id: 1, name: 'jack' })
// watch监听数据 watch(基本数据类型 || 数组 || 回调函数, 回调函数 , 配置项)// 1. 监听基本数据类型
// watch(num, (newVal, oldVal) => {
//   console.log('newVal:', newVal, '===oldVal', oldVal);
// })// 2.监听整个复杂数据类型 只能监听到新值,旧值无法显示
// watch(obj, (newVal, oldVal) => {
//   console.log('newVal:', newVal, '===oldVal', oldVal);
// })// 3.监听复杂数据类型的某一项数据,第一项改为函数
// watch(() => obj.id, (newVal, oldVal) => {
//   console.log('newVal:', newVal, '===oldVal', oldVal);
// })// 4.同时监听简单数据类型和复杂数据类型,第一项改为数组
watch([() => obj.id, num], (newVal, oldVal) => {console.log('newVal:', newVal, '===oldVal', oldVal);
})
/**i* * newVal: (2) [2, 1] ===oldVal (2) [1, 0]newVal: (2) [3, 2] ===oldVal (2) [2, 1]newVal: (2) [4, 3] ===oldVal (2) [3, 2]newVal: (2) [5, 4] ===oldVal (2) [4, 3]*/
</script>
<style></style>
  • 使用 watch 监听,配置默认执行:

  •   {// 开启深度监听deep: true,// 默认执行一次immediate: true
    }
    

6. 父传子与子传父(defineProps与defineEmits)

  • 实现组件通讯中的父子组件通讯

子组件:

<template><div><h1>son</h1><button @click="toFather">子向父传值</button></div>
</template>
<script setup>
// 父传子---子接收:
const props = defineProps({name: String,num: String
})
console.log(props);
console.log(props.name, props.num);
//--------------------
// 子向父传值
const emit = defineEmits(['sonHandle'])
const toFather = function () {emit('sonHandle', '我是子组件son')
}</script>
<style></style>

父组件:

<template><div><Son name="sunny" :num="num" @sonHandle="sonHandle($event)"></Son>===</div>
</template>
<script setup>
import Son from './components/son.vue'
import { ref } from "vue";
const num = ref('123')
const sonHandle = (e) => {console.log(e);
}
</script>
<style></style>

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

easyX实践上手操作小项目

easyX实践上手操作小项目 效果展示主菜单的装饰玩法介绍界面开始游戏界面制作团队界面排行榜界面注&#xff1a;main()函数拓展数据库小结 这里我们学习过easyX的基础知识后&#xff0c;看看是否能实践操作一下&#xff0c;制作一个属于自己的游戏界面呢&#xff1f; 基础知识…

Verilog初级教程(13)Verilog中的块语句

文章目录 前言正文串行语句并行语句并行块内包含串行块的情况块名称 往期文章回顾 前言 所谓的块语句&#xff0c;无非就是一组语句&#xff0c;例如在initial或者always中&#xff0c;使用begin…end或者fork…join包裹的语句&#xff0c;都可以称为块语句。块语句有两种&…

Verilog初级教程(11)Verilog中的initial块

文章目录 前言正文语法格式initial块是用来干什么的&#xff1f;initial块何时开始又何时结束&#xff1f;一个模块中允许有多少个initial块&#xff1f; 参考资料写在最后 前言 仿真中通常会依次执行一组Verilog语句。这些语句被放置在一个程序块中。在Verilog中主要有两种类…

Verilog初级教程(8)Verilog中的assign语句

博文目录 写在前面正文赋值语法reg类型变量赋值隐性连续赋值组合逻辑设计举例说明 参考资料交个朋友 写在前面 本系列相关博文链接&#xff1a; Verilog初级教程&#xff08;7&#xff09;Verilog模块例化以及悬空端口的处理 Verilog初级教程&#xff08;6&#xff09;Veril…

夏宇闻《Verilog数字系统设计教程》 - 第1章 Verilog的基本知识

第1章 Verilog的基础知识 1.1 硬件描述语言HDL 硬件描述语言&#xff08;HDL&#xff0c;hardware description language&#xff09;是一种用形式化方法来描述数字电路和系统的语言。 设计者使用HDL设计数字系统后&#xff0c;通过电子设计自动化工具&#xff08;EDA&#…

Verilog初级教程(12)Verilog中的generate块

文章目录 前言正文generate forgenerate ifgenerate case 参考资料本系列博文 前言 verilog中的generate块可以称为生成块&#xff0c;所谓生成&#xff0c;可以理解为复制。如果不太好理解&#xff0c;下面我们继续使用generate块。 generate块应用的场合通常是对模块进行批…

Verilog初级教程(17)Verilog中的case语句

文章目录 前言正文语法例子硬件原理图case与if-else有什么不同&#xff1f; 往期回顾参考资料及推荐关注 前言 case语句检查给定的表达式是否与列表中的其他表达式之一相匹配&#xff0c;并据此进行分支。它通常用于实现一个多路复用器。 如果要检查的条件很多&#xff0c;if…

Verilog初级教程(3)Verilog 数据类型

文章目录 前言正文变量可以取什么样的值&#xff1f;变量的取值意味着什么&#xff1f;主要的数据类型其他数据类型integertime / realtimereal例子 Verilog的字符串 写在最后 前言 这是本系列的第三篇博文&#xff0c;依然很基础&#xff0c;这个系列文章&#xff0c;主要是在…

Verilog初级教程(10)Verilog的always块

博文目录 写在前面正文语法什么是敏感列表&#xff1f;always块是用来干什么的&#xff1f;如果没有敏感列表怎么办&#xff1f;时序逻辑实例组合逻辑实例注意事项 参考资料 写在前面 由于刚毕业&#xff0c;又发生了很多事&#xff0c;在进入工作的准备期&#xff0c;就这样一…

verilog 入门教程

verilog 入门教程 1.1 什么是Verilog HDL? 1.2 Verilog的历史 1.3 Verilog的主要描述能力 2.1 Verilog-模块 2.2 Verilog-时延 2.3 Verilog-assign语句 2.4 Verilog-initial语句 2.5 Verilog-always语句 2.6 Verilog的结构化描述形式 2.7 Verilog-混合设计描述方式 2.8 Veri…

Verilog初级教程(14)Verilog中的赋值语句

文章目录 前言正文合理的左值过程性赋值&#xff08;Procedural assignment&#xff09;连续赋值过程连续性赋值 往期回顾 前言 何为赋值语句&#xff1f;即将值放到线网或者变量上&#xff0c;这种操作称为赋值&#xff0c;英文&#xff1a;assignment. 它有三种基本形式&…

嵌入式开发Verilog教程(二)——Verilog HDL设计方法概述

嵌入式开发Verilog教程&#xff08;二&#xff09;——Verilog HDL设计方法概述 前言一、Verilog HDL语言简介1.1 Verilog HDL语言是什么1.2 Verilog HDL设计复杂数字电路的优点1.2.1 传统设计方法——电路原理图输入法1.2.2 Verilog HDL设计方法与传统设计方法相比较的优势1.2…

嵌入式开发Verilog教程(三)——Verilog HDL基本语法汇总(上)

嵌入式开发Verilog教程&#xff08;三&#xff09;——Verilog HDL基本语法汇总&#xff08;上&#xff09; 前言一、简单的Verilog HDL模块1.1 Verilog HDL程序简单模块1.2 Verilog HDL程序模块结构1.3 Verilog HDL程序模块端口定义1.4 Verilog HDL程序模块内容 二、Verilog H…

SANXIN-B01开发板verilog教程V3电子版

今天给大侠带来“SANXIN-B01开发板verilog教程V3-郝旭帅团队电子版”,V3版本更新了后几章节的高级设计部分,获取电子版资料,请点击左下角阅读原文,跳转叁芯智能科技官方技术论坛下载,或者登录网址www.sxznfpga.com下载。 叁芯智能科技-郝旭帅团队打造“FPGA 设计与研发”学…

Verilog 教程

第一章&#xff1a;Verilog 简介 1.1 Verilog 教程 1.2 Verilog 简介 1.3 Verilog 环境搭建 1.4 Verilog 设计方法第二章&#xff1a;语法要素 2.1 Verilog 基础语法 2.2 Verilog 数值表示 2.3 Verilog 数据类型 2.4 Verilog 表达式 2.5 Verilog 编译指令 第三章…

ol中不同区域加载不同底图

概述 写一篇水文&#xff0c;讲讲如果在openlayers中实现不同的区域加载不同的底图。 效果 实现 通过tileUrlFunction实现不同切片地址的请求。 <!DOCTYPE html> <html><head><title>XYZ</title><link rel"stylesheet" href&qu…

数电/数字电子技术期末考前突击复习(小白稳过,看这一篇就够了)

博主&#xff1a;命运之光 专栏&#xff1a;期末考试必过and不挂科and争高分&#x1f636;‍&#x1f32b;️还有其他科目的考试突击日后会陆续更新 ✨✨✨✨✨点赞&#xff0c;关注&#xff0c;收藏不迷路✨✨✨✨✨ &#x1f984;前言&#xff1a;总结了期末数电大概率可能…

windows 10下载安装mysql5.7

MySQL数据库在日常使用是非常的频繁的&#xff0c;不管是线上还是线下。下面我就分享出我安装MySQL5.7的一步一脚印的教程&#xff0c;本教程只针对windows版本。 下载 MySQL官网下载地址&#xff1a;https://downloads.mysql.com/archives/community/ 选择对应的系统和版本…

【明解STM32】中断系统理论基础知识篇之中断寄存器功能原理

目录 一、前言 二、寄存器概述 三、NVIC寄存器组 四、SCB寄存器组 五、中断屏蔽寄存器组 六、总结 一、前言 在之前的STM32的中断系统理论基础知识之基本原理及NVIC中&#xff0c;分别中断的基本原理&#xff0c;中断的管理机制和中断的处理流程进行了较为详细的论述&…

mysql.exe下载_mysql8 windows 下载安装

一. 下载 点击download 可以注册登录&#xff0c;嫌麻烦的话直接点击NO&#xff0c;thanks… 开始下载 二. 安装 下载完成后得到一个zip包 我是安装板和解压即用版都下了&#xff0c;但用的解压即用版本&#xff0c;比较方便 解压mysql-8.0.17-winx64.zip&#xff0c;得到mysql…