当前位置: 首页 > wzjs >正文

陕西恒立建设集团网站线上怎么做推广和宣传

陕西恒立建设集团网站,线上怎么做推广和宣传,哈尔滨 房产网站建设,模板速成网站文章目录 前言什么是 provide 和 inject?provide 的基本使用inject 的基本使用provide 提供响应式数据数据provide 提供修改数据的方法provide 提供只读响应数据provide 使用symbol作为注入名inject 默认值总结 前言 在 Vue 3 中,provide 和 inject 是一…

文章目录

    • 前言
    • 什么是 provide 和 inject?
    • provide 的基本使用
    • inject 的基本使用
    • provide 提供响应式数据数据
    • provide 提供修改数据的方法
    • provide 提供只读响应数据
    • provide 使用symbol作为注入名
    • inject 默认值
    • 总结

前言

在 Vue 3 中,provideinject 是一对强大的 API,用于实现跨组件的依赖注入。无论是构建大型应用,还是编写组件库,它们都能帮助你以更优雅的方式管理数据共享。本文将带你深入理解 provideinject 的使用方法,并通过生动的示例,展示如何在实际项目中灵活运用

什么是 provide 和 inject?

provide inject 是 Vue 3 提供的一种跨组件通信机制。与 propsemit 不同,它们允许祖先组件向任意深度的后代组件传递数据,而无需逐层传递。这种机制在以下场景中尤为有用:

  • 共享全局状态(如用户信息、主题配置)。
  • 构建高阶组件或插件。
  • 避免 props 层层传递的繁琐。

provide 的基本使用

provide 用于在祖先组件中提供数据,供后代组件注入。它接受两个参数:

  • key:注入名,可以是字符串Symbol
  • value:要注入的值。

与注册生命周期钩子的 API 类似,provide() 必须在组件的 setup() 阶段同步调用。

类型:
在这里插入图片描述

示例:
在这里插入图片描述

inject 的基本使用

inject 用于在后代组件中注入祖先组件或全局应用注入(app.provide())提供的数据。它接受两个参数:

  • key:注入名。
  • defaultValue(可选):当未找到匹配的 key 时使用的默认值。

与注册生命周期钩子的 API 类似,inject() 必须在组件的 setup() 阶段同步调用。

类型
在这里插入图片描述

注入数据
第一个参数是注入的 key。Vue 会遍历父组件链,通过匹配 key 来确定所提供的值。如果父组件链上多个组件对同一个 key 提供了值,那么离得更近的组件将会“覆盖”链上更远的组件所提供的值。如果没有能通过 key 匹配到值,inject() 将返回 undefined

示例:
在这里插入图片描述
需要注意的是如果父组件提供的数据是非响应式数据, 当父组件数据的变化,子组件数据不会改变, 视图不会更新渲染
但如果父组件提供的值是一个 ref,注入进来的会是该 ref 对象,而不会自动解包为其内部的值。这使得注入方组件能够通过 ref 对象保持了和供给方的响应性链接。


provide 提供响应式数据数据

在提供数据时,可以提供响应式数据, 这样当提供数据发生变化时, 注入的数据也会发生变化

示例
在这里插入图片描述

当提供的响应数据user发生变化时,注入的组件显示的result 内容也会更新

provide 提供修改数据的方法

当提供/注入响应式的数据时,建议尽可能将任何对响应式状态的变更都保持在供给方组件中。这样可以确保所提供状态的声明和变更操作都内聚在同一个组件内,使其更容易维护。

如果你需要在注入组件中修改数据, 可以在提供时提供一个修改方法, 在注入组件内使用这个方法

示例
在这里插入图片描述

provide 提供只读响应数据

如果你不希望子组件中直接修改响应数据, 可以提供一个readonly 包装的只读数据

示例
在这里插入图片描述

provide 使用symbol作为注入名

至此,我们已经了解了如何使用字符串作为注入名。但如果你正在构建大型的应用,包含非常多的依赖提供,或者你正在编写提供给其他开发者使用的组件库,建议最好使用 Symbol 来作为注入名以避免潜在的冲突。

使用
在这里插入图片描述

当使用 TypeScript 时,key 可以是一个被类型断言为 InjectionKeysymbolInjectionKey 是一个 Vue 提供的工具类型,继承自 Symbol,可以用来同步 provide() inject() 之间值的类型。

使用
在这里插入图片描述

inject 默认值

inject 第二个参数是可选的,即在没有匹配到 key 时使用的默认值。它也可以是一个工厂函数,用来返回某些创建起来比较复杂的值。如果默认值本身就是一个函数,那么你必须将 false 作为第三个参数传入,表明这个函数就是默认值,而不是一个工厂函数。

示例
在这里插入图片描述

总结

provideinject 为 Vue 3 提供了一种优雅的跨组件通信方式。无论是共享全局状态,还是避免 props 层层传递,它们都能帮助你以更简洁的方式管理应用数据。通过本文的学习,相信你已经掌握了 provideinject 的核心用法。在实际开发中,灵活运用这些技巧,可以让你的代码更高效、更优雅。

如果你有任何疑问或想法,欢迎在评论区分享!🌟

http://www.dtcms.com/wzjs/330851.html

相关文章:

  • 淘宝网页模板免费下载关键词优化怎么弄
  • 如何创网站seo代码优化
  • 泗洪建设局网站好用的百度网盘搜索引擎
  • 网站怎么做自然优化seo什么意思
  • 怎么做网站关键词优化免费发布软文广告推广平台
  • 网线水晶头接法顺序seo主要是指优化
  • 贵阳建站推广公司seo如何建立优化网站
  • 韶关做网站需要多少钱电商平台哪个最好最可靠
  • 深圳建设网站个人网上怎么找客户资源
  • wordpress最佳服务器配置长沙seo网站排名优化公司
  • 专门做吃播的网站经典软文文案
  • 建设通网站登录不进去百度竞价排名是以什么形式来计费的广告?
  • 衣邦人上门定制靠谱吗百度seo还有前景吗
  • 英文网站建设比较好浏览器广告投放
  • 织梦 网站复制宁波做网站的公司
  • 网购网站建设论文如何搭建网站平台
  • 网站开发专员招聘百度公司简介介绍
  • 免费空间做网站如何开发自己的小程序
  • 网站什么时候恢复彩色上海百度seo公司
  • sm做任务的网站有哪些百度关键词相关性优化软件
  • 给别人做网站的销售叫什么线上广告推广
  • 网站建设公司下载企业网络推广
  • 濮阳建设工程网站2023年8月份新冠
  • 新建免费网站免费建设网站平台
  • 淘宝网站上的图片是怎么做的附近的电脑培训班在哪里
  • 手机网站制作 费怎么做分录成都私人网站建设
  • 南宁学网站开发老师直播课
  • 淘宝客怎么做网站推广如何优化网络延迟
  • 手机网站域名注册网站seo运营培训机构
  • 做个网站多少费用百度快照投诉中心人工电话