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

廊坊哪里做网站好友情链接站长平台

廊坊哪里做网站好,友情链接站长平台,今日头条湖北最新消息,可以自己免费做的软件组件间通信方式是前端必不可少的知识点,前端开发经常会遇到组件间通信的情况,而且也是前端开发面试常问的知识点之一。接下来开始组件间通信方式第三弹------$bus,并讲讲分别在Vue2、Vue3中的表现。 Vue2Vue3组件间通信方式汇总(1&#xff09…

 组件间通信方式是前端必不可少的知识点,前端开发经常会遇到组件间通信的情况,而且也是前端开发面试常问的知识点之一。接下来开始组件间通信方式第三弹------$bus,并讲讲分别在Vue2、Vue3中的表现。

Vue2+Vue3组件间通信方式汇总(1)------props

Vue2+Vue3组件间通信方式汇总(2)------$emit

一、全局总线$bus 原型链

归根结底就是在vm,vue原型链上注册一个名叫$bus 的对象,再把this,就是vm实例对象赋给$bus,其中$on $emit $off等就是全局可以读可写的变量,即可实现,相关组件、不相关组件之间数组地传递。

------Vue2 

main.js文件中,Vue实例下,往Vue原型链上注册属性:$bus

//引入Vue
import Vue from 'vue'
//引入App
import App from './App.vue'
//关闭Vue的生产提示
Vue.config.productionTip = false//创建vm
new Vue({el:'#app',render: h => h(App),beforeCreate() {Vue.prototype.$bus = this//注册全局事件总线}
})

其中一个组件:调用全局总线的$emit:

<template><div class="student"><h2>学生姓名:{{name}}</h2><h2>学生性别:{{sex}}</h2><button @click="sendStudentName">把学生名给另一个组件</button></div>
</template><script>export default {name:'Student',data() {return {name:'张三',sex:'男',}},methods:{sendStudentName(){this.$bus.$emit('hello',this.name)}}}
</script><style scoped>.student{background-color: pink;padding: 5px;margin-top: 30px;}
</style>

 另一个组件:调用全局总线的$on:

<template><div class="school"><h2>学校名称:{{name}}</h2><h2>学校地址:{{address}}</h2></div>
</template><script>export default {name:'School',data() {return {name:'学校名',address:'学校地址',}},mounted() {this.$bus.$on('hello',(data) => { //绑定自定义事件hello,并留下回调函数console.log('我收到了'+data);})},beforeDestroy() {this.$bus.$off('hello')			},}
</script><style scoped>.school{background-color: skyblue;padding: 5px;}
</style>
 ------Vue3   不存在vm所以需要引入mitt插件

npm install mitt

在bus.ts文件中引入: 

import mitt from "mitt"
//mitt是一个函数,赋给命名为$bus的变量
const $bus=mitt();
//向外暴露这个变量
export default $bus

 其中一个组件:

使用mitt中的$emit函数,向$on传输数据,第一个参数是和$on第一个参数向对应的字段名,余下的参数是要传输的数据,和Vue实例对象上的$emit,$on用法差不多.

<template><div class="student"><h2>学生姓名:{{name}}</h2><h2>学生性别:{{sex}}</h2><button @click="sendStudentName">把学生名给另一个组件</button></div>
</template><script setup lang="ts">
import ref from "vue"
import $bus from "./bus.ts"
let name=ref("张三")
let sex=ref("男")
let sendStudentName=(name.value)=>{
//使用mitt中的$emit函数,向$on传输数据,第一个参数是和$on第一个参数向对应的字段名,余下的参数是要传输的数据,和Vue实例对象上的$emit,$on用法差不多.$bus.$emit("hello",name.value)
}
</script><style scoped>.student{background-color: pink;padding: 5px;margin-top: 30px;}
</style>

 另一个组件:$on接收数据

<template><div class="student"><h2>学生姓名:{{name}}</h2><h2>学生性别:{{sex}}</h2><button @click="sendStudentName">把学生名给另一个组件</button></div>
</template><script setup lang="ts">
import {ref,onMounted) from "vue"
import $bus from "./bus.ts"
let name=ref("张三")
let sex=ref("男")
onMounted(()=>{$bus.$on("hello",(data)=>{name.value=data})})</script><style scoped>.student{background-color: pink;padding: 5px;margin-top: 30px;}
</style>
http://www.shuangfujiaoyu.com/news/28067.html

相关文章:

  • 深圳自适应网站制作微信推广引流方法
  • wordpress 站长主题seo常用优化技巧
  • 做电影网站 广告收入网站页面关键词优化
  • 宿州城市建设投资网站线上营销怎么做
  • 如何用h5做网站郑州网络推广代理
  • wordpress搜索查询插件seo外包 靠谱
  • 两学一做网上答题网站湖南seo
  • 深圳房管局官网中国seo关键词优化工具
  • asp网站建设教案软文写作什么意思
  • 其他公司盗用公司名做网站重庆公司网站seo
  • 网站的经营方式武汉大学人民医院精神科
  • 2018做网站的视频厦门seo蜘蛛屯
  • 福州网站建设外包重庆网站seo公司
  • 行业网站的特点上海高端seo公司
  • 外贸网站建设价格杭州seo百度关键词排名推广
  • 做站群一个网站多少钱企业培训考试系统
  • 莆田社交网站草根站长工具
  • 宁波网站推广平台咨询公司百度电商平台
  • 法院网站建设情况苏州网站建设方案
  • 创建全国文明城市要求注册志愿者seo有哪些优缺点?
  • 工业设计代做网站资讯门户类网站有哪些
  • 体育直播网站开发数据源获取营销网络是什么
  • 大连建设网站株洲seo推广
  • 内销常用网站外贸推广具体是做什么
  • 网站页面布局分析嘉兴百度seo
  • 外贸建站效果服务营销案例100例
  • 做系统去哪网站下载镜像灰色广告投放平台
  • 自己怎么拍做美食视频网站推广渠道有哪些方式
  • 淘宝客商品推广网站建设中央广播电视总台
  • 南京建设工程监管网站项目平台