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

网站多少钱一年武汉网站推广公司排名

网站多少钱一年,武汉网站推广公司排名,wordpress自动修改图,正规的代练接单平台provide 和 inject 是 Vue.js 中用于实现依赖注入的两个关联功能。它们允许你在祖先组件中提供数据,然后在子孙组件中注入这些数据,实现组件之间的数据共享和传递。 provide:provide 是一个选项,你可以在父组件中通过它来提供数据…

provide 和 inject 是 Vue.js 中用于实现依赖注入的两个关联功能。它们允许你在祖先组件中提供数据,然后在子孙组件中注入这些数据,实现组件之间的数据共享和传递。

  • provide:provide 是一个选项,你可以在父组件中通过它来提供数据。你可以在 provide 选项中声明要共享的数据。这些数据可以是任何 JavaScript 值,包括对象、函数等。

  • inject:inject 是另一个选项,你可以在子孙组件中通过它来注入父组件提供的数据。inject 的值是一个包含了你想要注入的属性名称的数组或对象。

App.vue

<template><h1>App.vue(爷爷级别)</h1><label><input v-model="colorVal" value="red" name="color" type="radio">红色</label><label><input v-model="colorVal" value="pink" name="color" type="radio">粉色</label><label><input v-model="colorVal" value="yellow" name="color" type="radio">黄色</label><div class="box"></div><hr><provideAVue></provideAVue>
</template><script setup lang="ts">
import {ref, reactive, inject, readonly,provide} from 'vue'
import provideAVue from './components/provideA.vue'
const colorVal = ref<string>('red')
provide('color', colorVal)
// 为防止子组件修改color的值,可以用readonly绑定 provide('color', readonly(colorVal))
</script><style scoped>
.box {height: 50px;width: 50px;border: 1px solid #ccc;background: v-bind(colorVal);
}
</style>

provideA.vue

<template><h1>provideA.vue(父亲级别)</h1><div class="box"></div><hr><provideBVue></provideBVue>
</template><script setup lang="ts">
import { ref, reactive, inject } from 'vue';
// 直接<ref<string>>会报错:'ref' refers to a value, but is being used as a type here. Did you mean 'typeof ref'?  需要用<Ref<string>> 引入 type {Ref}
import type {Ref} from 'vue'
import provideBVue from './provideB.vue'
const color = inject<Ref<string>>('color')</script><style scoped>
.box {height: 50px;width: 50px;border: 1px solid #ccc;background: v-bind(color);
}
</style>

provideB.vue

<template><h1>provideB.vue(孙子级别)</h1><div><button @click="change">修改 provide 的值 yellow</button></div><div class="box"></div><hr><provideBVue></provideBVue>
</template><script setup lang="ts">
import { ref, reactive, inject } from 'vue';
import type { Ref } from 'vue'
const color = inject<Ref<string>>('color', ref('red'))
// provide 传过来的值可以被子组件修改,不想被修改可以使用 readonly 对变量进行绑定
const change = () => {// 报错:'color' is possibly 'undefined'.  // color.value = 'yellow'// 报错:The left-hand side of an assignment expression may not be an optional property access.// color?.value = 'yellow'// 解决方法一:使用 !. 非空断言解决// color!.value = 'yellow'// 解决方法二:添加默认值, ref('red')color.value = 'yellow'
}</script><style scoped>
.box {height: 50px;width: 50px;border: 1px solid #ccc;background: v-bind(color);
}
</style>

需要注意的是,provide 和 inject 不适用于跨级的父子组件关系,因为 Vue 的设计是鼓励将组件树限制在父子关系中,而不是过多地嵌套。在跨级关系中,你可能需要使用 Vuex 或事件总线等其他方法来实现数据共享。

http://www.ds6.com.cn/news/117793.html

相关文章:

  • 自己做网站打不开是怎么回事排名优化网站
  • 峰峰专业做网站网站推广论坛
  • 密云区住房和城乡建设委员会网站6河南网站优化排名
  • 静态网站设计模板百度推广账户优化方案
  • 潍坊专业网站建设价格低百度百度一下你就知道主页
  • 环境设计专业必看网站百度怎么发免费广告
  • 永川网站建设百度联盟怎么加入
  • 怎样设计一个网站平台企业营销策划包括哪些内容
  • 酒店网站建设策划书每日军事新闻
  • 做同城信息类网站如何赚钱比较开放的浏览器
  • 做网站设计制作的seo网站结构优化
  • 东莞响应式网站制作爱站网长尾关键词挖掘工具下载
  • 做网站必须要注册公司么公司网站免费建站
  • shopify建站教程苏州旺道seo
  • 南宁 做网站桂林市天气预报
  • 如何做像淘宝一样的网站网页制作的软件
  • 虚拟机下载seo优化一般优化哪些方面
  • 什么大的网站是帝国cms做的济南疫情最新情况
  • 旅游网站设计与建设论文深圳seo公司助力网络营销飞跃
  • 柳州城市的城乡建设管理局网站线下推广方法有哪些
  • 国外网站icp备案快速seo软件
  • 企业网站建设可以分为几个层次武汉百度推广开户
  • 重庆免费发布信息网站东莞做网站的公司有哪些
  • 做网站建设有哪些公司搜索引擎排名优化seo课后题
  • 番禺制作网站报价关键词挖掘工具有哪些
  • 设计大神云集的网站是seo优化裤子关键词
  • 独立网站商城建设谷歌浏览器官网入口
  • 永嘉网站建设咸宁网站seo
  • 大连网站建设方案维护seo优化工具软件
  • 百度站长工具数据提交百度竞价推广方案的制定