Vue3常用知识点总结
admin
2024-02-23 09:39:11
0

一、vue3的基本介绍及项目创建

        Vue是一套用于构建用户界面的渐进式框架。Vue.js 3.0 "One Piece" 正式版在2020年9月份发布,经过了2年多开发, 100+位贡献者, 2600+次提交, 600+次PR,同时Vue3也支持Vue2的大多数特性,且,更好的支持了TypeScript,也增加了很多的新特性,如:Composition API,新组件(Fragment/Teleport/Suspense)等等

        详细介绍以及项目创建方式,可见之前发布的文章——

(2条消息) Vue3的基本介绍及创建方式_终将抵达丶的博客-CSDN博客icon-default.png?t=M85Bhttps://blog.csdn.net/gkx19898993699/article/details/127656687?spm=1001.2014.3001.5501

二、常用的组合API(setup、ref、reactive)

(一)setup

  •  新的option, 所有的组合API函数都在此使用, 只在初始化时执行一次
  • 函数如果返回对象, 对象中的属性或方法, 模板中可以直接使用
export default {name: "toRefs",setup () {let a = 6return {a},}
}

(二)ref

        ● 作用: 定义一个数据的响应式

        ●语法: const xxx = ref(initValue):

        ○创建一个包含响应式数据的引用(reference)对象

        ○js中操作数据: xxx.value

        ○模板中操作数据: 不需要.value

        ●一般用来定义一个基本类型的响应式数据

(三)reactive

  •  作用: 定义多个数据的响应式
  • const proxy = reactive(obj): 接收一个普通对象然后返回该普通对象的响应式代理器对象
  • 响应式转换是“深层的”:会影响对象内部所有嵌套的属性
  • 内部基于 ES6 的 Proxy 实现,通过代理对象操作源对象内部数据都是响应式的

以上三者的细节出可跳转到之前的文章——

(2条消息) Vue3中的组合式 (Composition) API(一)_终将抵达丶的博客-CSDN博客icon-default.png?t=M85Bhttps://blog.csdn.net/gkx19898993699/article/details/127656960?spm=1001.2014.3001.5501

三、比较Vue2与Vue3的响应式

(一)Vue2

  • 对象: 通过defineProperty对对象的已有属性值的读取和修改进行劫持(监视/拦截)
  • 数组: 通过重写数组更新数组一系列更新元素的方法来实现元素修改的劫持

(二)Vue3

  • 通过Proxy(代理): 拦截对data任意属性的任意(13种)操作, 包括属性值的读写, 属性的添加, 属性的删除等...

        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

1.Reflect.get(target, propertyKey)
         参数    (1)target:需要取值的目标对象
                    (2)propertyKey:需要获取的值的键值
                    (3)返回值:属性的值

2.Reflect.set(target, propertyKey, value)
         参数   (1)target:设置属性的目标对象。
                   (2)propertyKey:设置的属性的名称。
                   (3) value:设置的值
                   (4)返回值:返回一个 Boolean 值表明是否成功设置属性。

详情请跳转到之前发布的文章——

(2条消息) 比较vue2与vue3中的双向数据绑定_终将抵达丶的博客-CSDN博客icon-default.png?t=M85Bhttps://blog.csdn.net/gkx19898993699/article/details/127657812?spm=1001.2014.3001.5501

四、计算属性与监视

  • computed函数:
    • 与computed配置功能一致
    • 有getter和setter
  • watch函数
    • 与watch配置功能一致
    • 只有getter
    • 监视指定的一个或多个响应式数据, 一旦数据变化, 就自动执行监视回调
    • 默认初始时不执行回调, 但可以通过配置immediate为true, 来指定初始时立即执行第一次
    • 通过配置deep为true, 来指定深度监视
  • watchEffect函数
    • 不用直接指定要监视的数据, 回调函数中使用的哪些响应式数据就监视哪些响应式数据
    • 默认初始时就会执行第一次, 从而可以收集需要监视的数据
    • 监视数据发生变化时回调

详情请跳转到——

(2条消息) Vue3中的组合式 (Composition) API(一)_终将抵达丶的博客-CSDN博客icon-default.png?t=M85Bhttps://blog.csdn.net/gkx19898993699/article/details/127656960?spm=1001.2014.3001.5501

五、Vue3与Vue2的生命周期对比

与 2.x 版本生命周期相对应的组合式 API

  • beforeCreate -> 使用 setup()
  • created -> 使用 setup()
  • beforeMount -> onBeforeMount
  • mounted -> onMounted
  • beforeUpdate -> onBeforeUpdate
  • updated -> onUpdated
  • beforeDestroy -> onBeforeUnmount
  • destroyed -> onUnmounted
  • errorCaptured -> onErrorCaptured

新增的钩子函数

组合式 API 还提供了以下调试钩子函数:

  • onRenderTracked
  • onRenderTriggered

六、自定义hook函数

  •  使用Vue3的组合API封装的可复用的功能函数
  • 自定义hook的作用类似于vue2中的mixin(混入)技术
  • 自定义Hook的优势: 很清楚复用功能代码的来源, 更清楚易懂
  • 需求1: 收集用户鼠标点击的页面坐标hooks/useMousePosition.ts

1.创建一个hook函数的ts文件

import { ref, onMounted, onUnmounted } from 'vue'
/* 
收集用户鼠标点击的页面坐标
*/
export default function useMousePosition () {// 初始化坐标数据const x = ref(-1)const y = ref(-1)// 用于收集点击事件坐标的函数const updatePosition = (e: MouseEvent) => {x.value = e.pageXy.value = e.pageY}// 挂载后绑定点击监听onMounted(() => {document.addEventListener('click', updatePosition)})// 卸载前解绑点击监听onUnmounted(() => {document.removeEventListener('click', updatePosition)})return {x, y}
}

2.在需要的页面引入即可使用hook中的数据及方法

七、toRefs

 把一个响应式对象转换成普通对象,该普通对象的每个 property 都是一个 ref

        应用: 当从合成函数返回响应式对象时,toRefs 非常有用,这样消费组件就可以在不丢失响应式的情况下对返回的对象进行分解使用

        问题: reactive 对象取出的所有属性值都是非响应式的

        解决: 利用 toRefs 可以将一个响应式 reactive 对象的所有原始属性转换为响应式的 ref 属性

八、ref获取元素

注意:在script的标签内要加入  lang="ts"

利用ref函数获取组件中的标签元素

        注意:声明一个 ref 来存放该元素的引用
                   必须和模板里的 ref 同名

功能需求: 让输入框自动获取焦点

九、Vue3中是否使用<script setup>父子传参的不同(重点)

        个人认为这是Vue3中很重要的一个点,而且当你熟悉了以后会发现他真的比Vue2方便好多,其中详情请跳转到单独的文章——

(2条消息) Vue3中是否使用<script setup>父子传参的不同_终将抵达丶的博客-CSDN博客icon-default.png?t=M85Bhttps://blog.csdn.net/gkx19898993699/article/details/127690322?spm=1001.2014.3001.5501

相关内容

热门资讯

又有“高潜力”新股来了,此前超... 【导读】下周2只新股可申购,爱得科技申购上限排名2026年以来新股首位 中国基金报记者 闻言 A股打...
中电电机:股东王建裕计划减持公... 每经AI快讯,中电电机1月30日晚间发布公告称,截至本公告日,王建裕先生持有中电电机股份有限公司无限...
图解1月ETF涨跌幅、资金流 大家周末好呀~ 在刚刚过去的1月,巨量主力资金大动作。 2026年开年以来,A股ETF市场呈现鲜明分...
1亿注册资本落子深圳,南山铝业... 转自:山东财经报道 文|山东财经报道 贾义航 企查查显示,1月30日,南山铝业(600219....
腾讯元宝App升至苹果商店免费... 每经AI快讯,2月1日,腾讯元宝App升至苹果商店免费App第一名,此前宣布10亿现金红包活动开启。...
黄金跌9%、白银跌超26%,抄... 开年以来,白银价格最高涨超65%,多国正从政策层面强化其战略资源属性。在金融属性回归与工业需求扩张的...
特斯拉FSD付费用户已达110... 雷递网 雷建平 2月1日 特斯拉(Tesla)日前发布截至2025年12月31日的财报。财报显示,特...
49.98亿元!海螺集团将间接... 安徽省投资集团控股有限公司(下文简称“安徽省投资集团”)、安徽省国有资本运营控股集团有限公司(下文简...
又一家厦企被上市公司“看上”了 又一家厦企被上市公司“看上”了! 1月30日晚 上市公司深圳民爆光电股份有限公司 (以下简称民爆光电...
【新手必看】JANUVASTH... 行业痛点分析 当前,阿育吠陀疗法在全球健康产业中的接受度日益提升,但具体到如JANUVASTHI(一...
逾300万页爱泼斯坦文件公布,... 【文/观察者网 王恺雯】当地时间1月30日,美国司法部公布迄今为止数量最大的一批爱泼斯坦案相关文件。...
致亡率可达75%!印度暴发新疫... 近日,印度东部的西孟加拉邦出现尼帕病毒疫情,引发当地政府和国际社会的高度关注。截至目前,该邦已确诊5...
300567,预告扭亏为盈,近... 来源:e公司 公司预计2025年归属于上市公司股东的净利润为8000万元—9000万元,同比扭亏为盈...
“多杀多”引发惨剧 华尔街基金... 记者 陈植 2026年1月30日晚,张刚目不转睛地盯着电脑上的COMEX黄金、白银期货报价实时走势,...
下沙再添一个总部经济项目! 前段时间, 杭钱塘工出【2025】31号地块出让,东部湾新城又迎来一个总部经济项目。 据悉,该地块位...
原创 德... 1月27日,黄金的价格突破5000美元大关,那一刻,斯特拉斯堡的电子屏幕上不再是昔日的财富狂欢,而是...
银行“年终奖理财”卷疯了,有产... 来源:时代周报-时代在线 岁末更替之际,职场人期盼的2025年年终奖陆续到账,年终奖理财市场持续升温...
国家税务总局明确,个人打零工每... 近日,国家税务总局制发了《关于起征点标准等增值税征管事项的公告》,就起征点标准判定、税收优惠政策适用...
黄金闪崩9%!白银跌27%?别... 伦敦金现一天跌9.45%,A股黄金概念股大面积跌停;白银更是单日暴跌26.77%。一夜之间,曾经高歌...
周末这两大重要消息,对2月A股... 刚过去的交易周(1月26日至30日),A股整体呈现放量震荡格局,日均成交额超3万亿元。在大资金持续净...