位置: IT常识 - 正文

vue3生命周期及setup介绍(vue3生命周期及使用)

编辑:rootadmin
vue3生命周期及setup介绍 🌷 生命周期

推荐整理分享vue3生命周期及setup介绍(vue3生命周期及使用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3的生命周期函数,vue生命周期的四个阶段,vue3生命周期及干什么,vue生命周期详解,vue3的生命周期函数,vue3生命周期及使用,vue3生命周期及干什么,vue3 生命周期,内容如对您有帮助,希望把文章链接给更多的朋友!

下图对比了vue3(左)和vue2(右)的生命周期:vue3将destoryed该名成了unmounted,相应的beforeDestory改成了beforeUnmounted。除此之外在组合式API中新增了个钩子函数:setup。它发生在beforeCreate之前。 先简单介绍下setup函数:

setup() 钩子是在组件中使用组合式 API 的入口setup中没有thissetup函数只会在组件初始化的时候执行一次setup函数在beforeCreate生命周期钩子执行之前执行生命周期函数

与vue2不同,vue3中使用生命周期函数需要先导入生命周期钩子函数,并且生命周期函数可以调用多次。

<script lang="ts">import { onMounted } from 'vue'export default { setup() { onMounted(() => { console.log('mounted')})onMounted(() => { console.log('mounted two')}) }}</script>vue3生命周期及setup介绍(vue3生命周期及使用)

你也可以使用setup语法糖,看起来更简洁一些。

<script setup lang="ts">import { onMounted } from 'vue'onMounted(() => { console.log('mounted')})onMounted(() => { console.log('mounted two')})</script><style scoped></style>不同API的生命周期选项式API组合式APIbeforeCreate不需要(直接写到setup函数中)created不需要(直接写到setup函数中)beforeMountonBeforeMountmountedonMountedbeforeUpdateonBeforeUpdateupdatedonUpdatedbeforeDestroyedonBeforeUnmountdestroyedonUnmounted🍁setup介绍1. 访问Props

setup 函数的第一个参数是组件的 props。和标准的组件一致,一个 setup 函数的 props 是响应式的,并且会在传入新的 props 时同步更新。

export default { props: { title: String }, setup(props) { // 注意这里不要解构props,这样会使解构出来的变量失去响应性。如果一定要解构需要使用响应式api转发下。 console.log(props.title) }}2. setup上下文

传入 setup 函数的第二个参数是一个 Setup 上下文对象。上下文对象暴露了其他一些在 setup 中可能会用到的值:

export default { setup(props, context) { // 透传 Attributes(非响应式的对象,等价于 $attrs) console.log(context.attrs) // 插槽(非响应式的对象,等价于 $slots) console.log(context.slots) // 触发事件(函数,等价于 $emit) console.log(context.emit) // 暴露公共属性(函数) console.log(context.expose) }}

与props不同,上下文对象是非响应式的,可以安全地解构:

export default { setup(props, { attrs, slots, emit, expose }) { ... }}

attrs 和 slots 的属性都不是响应式的。如果你想要基于 attrs 或 slots 的改变来执行副作用,那么你应该在 onBeforeUpdate 生命周期钩子中编写相关逻辑。

expose函数用于显式地限制该组件暴露出的属性,当父组件通过模板引用访问该组件的实例时,将仅能访问 expose 函数暴露出的内容:

export default { setup(props, { expose }) { // 让组件实例处于 “关闭状态” // 即不向父组件暴露任何东西 expose() const publicCount = ref(0) const privateCount = ref(0) // 有选择地暴露局部状态 expose({ count: publicCount }) }}3. 与渲染函数一起使用

setup 也可以返回一个渲染函数,此时在渲染函数中可以直接使用在同一作用域下

本文链接地址:https://www.jiuchutong.com/zhishi/298408.html 转载请保留说明!

上一篇:Node.js最新版黑马配套笔记(node .js)

下一篇:分割网络损失函数总结!交叉熵,Focal loss,Dice,iou,TverskyLoss!(网络分割算法)

  • 所得税汇算清缴招待费扣除标准
  • 小型微利企业所得税计算公式2023
  • 哪些收据可以入帐
  • 小规模多计提增值税税率
  • 商业保险进项税额转出影响成本吗
  • 企业所得税应纳税额
  • 小规模企业现金流量表
  • 机票改签费能否抵税
  • 高铁票进项抵扣怎么在增值税系统申报
  • 电子发票字迹不清怎么办
  • 发货就要开票吗是真的吗
  • 临时聘用人员费用谁承担
  • 以无形资产投资入股缴纳哪些税收
  • 原材料盘亏会计分录怎么做
  • 建筑业营改增的主要内容
  • 应交增值税明细科目如何结转
  • 银行承兑汇票贴现利率一般多少
  • 酒店购入食材,怎么做会计分录
  • 员工社保异地缴纳
  • 如何区分纳税人和小规模纳税人
  • 购买理财产品会损失本金吗
  • 利润表季报表
  • 汇算清缴涉及长期投资收益如何做会计核算?
  • 接受国外企业捐款的条件
  • 研发费用的税收政策
  • 用友软件怎么反记账凭证
  • 银行哪些进项税不用抵扣
  • 考试资格的工作有哪些
  • 冲减预交的增值税税率
  • iphone7plus怎么设置5g网络
  • psdrvcheck.exe - psdrvcheck是什么进程 有什么用
  • 发放工资的时候,如何在excel里快速查询未发放成功的
  • 修改系统帐户用什么软件
  • 财务决算报表是谁编制的
  • windows没有搜索
  • bellzee.exe是什么
  • 除了个税还有什么税
  • 知乎如何更改名字
  • 格拉纳达的阿尔罕布拉宫用什么材料制成?
  • 金门大桥和马林大桥区别
  • 单目测距精度
  • pytorch的环境配置
  • 信息技术服务费税收编码
  • 已经红冲的发票显示正常
  • 帝国cms怎么调用文章随机段落
  • vue style import
  • 第四季度报表和年报对不上
  • 净资产包含哪些项目
  • 股份支付属于应付职工薪酬吗?
  • 劳务外经证预缴税款
  • 小规模增值税纳税人优惠政策
  • 旅游业营改增会计分录
  • 软件即征即退开票信息与资料不符
  • 公司用卫生纸是干什么的
  • 珠宝行业的会计处理方式
  • 库存现金余额过大的风险
  • 资源税代扣代缴取消时间
  • 税金附加科目有哪些
  • 余额调节表一定要编制吗
  • 工会经费计提的比例是多少
  • 个税申报工资比实发工资高
  • 申报高新技术企业专利有什么要求
  • 倒卖承兑汇票被判刑
  • 货款已付对方不发货的案例分析
  • linux系统中
  • mysqladmin ping
  • mysql使用语句
  • my sql命令
  • WinXp x64sp企业订户最新完整纯净版安装指南
  • linux 中断 处理
  • 删除同步中心图标
  • python的判断语句
  • cocos creator读取json
  • android自定义属性详解
  • [置顶]JM259194
  • js中的垃圾回收机制有哪些方法
  • 美国消费比例
  • 一般纳税人开红字发票怎么报税
  • 苏州吴江区事业单位2023成绩公布
  • 上市股票转为非上市
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设