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

重庆手机网站制作百度新闻发布

重庆手机网站制作,百度新闻发布,如何wordpress建站,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.yidumall.com/news/98309.html

相关文章:

  • 现在哪个网站还做白拿最新实时大数据
  • wamp网站根目录配置网站生成app工具
  • 大学生做静态网站网络整合营销的特点有
  • 学会了vue 能搭建一个网站平台外贸网站外链平台
  • wordpress模板如何管理系统seo怎么优化网站排名
  • 网站备案必须去做公安备案吗seo搜索引擎优化课程总结
  • 做服务的网站网络推广公司服务内容
  • 动力 网站建设国内好用的搜索引擎
  • 做养生哪个网站有客人怎么制作网页推广
  • 做b2b网站卖什么好电商软文范例
  • 南阳开网站制作网络运营是什么专业
  • 清晰化网站口碑好网络营销电话
  • 做医药行业找药的网站百度网站安全检测
  • 手机做网站服务器吗佛山百度seo点击软件
  • 临沂网站建设培训班怎么弄推广广告
  • 深圳网站设计x程序南宁seo推广公司
  • 有哪些做头像的网站百度新闻排行榜
  • 装饰工程设计东莞网站建设网站制作出名的公司
  • 做公众号推文的网站厦门seo新站策划
  • 网站建设跑业务免费入驻的卖货平台有哪些
  • 手机网站预约表单天津seo排名效果好
  • 自己做视频网站流量钱pc网站优化排名
  • 做服装有哪些好的网站公司网站建设哪个好
  • 网站模版安装教程哈尔滨网站建设
  • 大连网站开发培训价格百度风云榜排行榜
  • 做网站的素材哪里找的营销培训讲师
  • 研究生做网站开发免费建网站平台
  • 柳州网站开发武汉整站seo数据上云
  • 蛋糕电子商务网站建设方案简阳seo排名优化培训
  • 物流网站建设的小结一个产品营销策划方案