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

相关内容

热门资讯

原创 5... 今天早上9点40分,国内现货黄金的人民币报价来到了1029.53元每克,算下来比昨天跌了4.78块钱...
雷军追慕马斯克,深谙时代造王规... 今天亿万富翁马斯克到访中国,瞬间成为舆论热议焦点,一系列故事也让人津津乐道。 上午现身人民大会堂,一...
最新!邢台500亿国企董事长换... 5月12日,河北顺德投资集团有限公司发布重大人事变动公告。 根据相关文件,公司原董事、总经理翟义琢...
新华图讯 | 习近平为美国总统... 5月14日晚,国家主席习近平在北京人民大会堂举行宴会,欢迎美国总统特朗普访华。 摄影:李...
原创 拿... 如果你交的税款被政府拿去在股市里“冲杀”,你会觉得这是发财的机遇,还是崩盘的前兆? 就在最近,特朗普...
畅通小微金融服务堵点 国家开发银行最新发布的数据显示,今年一季度,该行发放稳外贸专项转贷款285.4亿元,支持外贸小微企业...
原创 白... 2026年5月11日晚间,伦敦现货白银市场出现剧烈波动,单日大幅拉升近7%,盘中价格一度逼近86美元...
美股收盘:三大指数集体收涨,英... 美东时间周四,美国三大股指全线收涨。截至收盘,道指涨0.75%报50063.46点,标普500指数涨...
【聚焦】汇总 | 52家包装印... 根据中国证券报网站公开信息,中国印工协出版物印刷资讯汇总整理了52家包装印刷产业链上市公司2025年...
Cerebras上市首日股价飙... 5月15日消息,据CNBC报道,人工智能芯片制造商Cerebras周四在纳斯达克上市首日股价飙升68...
2026年 鞍钢电工钢供货渠道... 在新能源、高效节能变压器及高端电机产业快速发展的背景下,电工钢作为关键软磁材料,其供应链的稳定性与专...
白酒板块久违“吸金”!成交额创... 财联社5月14日讯(编辑 梓隆),今日(5月14日),白酒板块迎来久违的热度修复,截至收盘,剔除停牌...
携程、美团、阿里抢的不是旅游攻... 今年五一,旅游行业有个变化特别明显。 不是游客多了,也不是机票酒店卖爆了,而是用户开始把“决策权”交...
中美科技大佬同席特朗普访华欢迎... 本文来源:消费者报道 作者:肖道 5月14日晚,欢迎美国总统特朗普访华的宴会在北京人民大会堂举行,中...
成都这杯“盖碗茶”为全球投资者... 一杯盖碗茶,品出的是一座城市与世界双向奔赴的开放姿态。5月14日下午,作为2026成都国际友城合作与...
AI购物聊了两年,为什么今天才... 文|王熠 一个用户对千问说:“我想减肥,帮我推荐一些训练装备。” 千问的回答是:不建议买,你拥有的...
美参议院批准凯文·沃什出任美联... 当地时间5月13日,央视记者获悉,美国国会参议院当日以54票赞成、45票反对的投票结果,正式批准凯文...
测血糖怕疼、嫌麻烦?这6个方法... “一天扎好几次手指,手指头都快成筛子了……” “每次测血糖之前都紧张半天,下不去手。” “上班忙、带...
洋河迎来价值重估时刻:从消费者... 5月12日,洋河股份举行2025年度网上业绩说明会。洋河股份董事长、总裁顾宇带领管理层集体出席。 这...
四大指数集体收跌,沪指失守42... 每经记者:杜波 记者|杜波 编辑|陈柯名杜恒峰校对|程鹏 14日,A股市场震荡调整,截至收盘,创业...