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

会唐网做网站软件定制开发

会唐网做网站,软件定制开发,pr模板免费下载网站,房屋设计装修app组件间通信方式是前端必不可少的知识点,前端开发经常会遇到组件间通信的情况,而且也是前端开发面试常问的知识点之一。接下来开始组件间通信方式第三弹------$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.wangmingla.cn/news/81635.html

相关文章:

  • 房产门户网站模板外链代发平台
  • 用php做的网站实例怎么推广游戏叫别人玩
  • 黑龙江住房和城乡建设部网站徐州seo外包
  • 网站推广的宣传途径网络软文营销案例
  • 网站推广广告申请企业网站制作流程
  • 怎么做网盘搜索网站深圳seo排名
  • 网站怎么做任务赚钱软文广告经典案例300
  • 有自己网站做淘宝客赚钱百度站长提交网址
  • web前端怎么学seo公司推荐
  • 男女做爰免费网站网站服务器
  • 怎么做网站首页线上营销方案
  • 网站数据怎么做论文注释北京朝阳区疫情最新情况
  • vps网站压缩指数分布的分布函数
  • 长沙招聘网站制作电话营销
  • 开什么网站暴利南宁seo咨询
  • 手机上自己如何做网站seo关键词排名优化制作
  • 理财网站如何做推广方案整合营销传播名词解释
  • 建筑工程网价是什么意思seo描述是什么
  • 做网站服务销售网站营销外包哪家专业
  • 做网站页面的软件发稿平台
  • 免费的企业网页制作网站网络营销的概念和含义
  • wordpress 阅读数惠州搜索引擎优化
  • 深圳做网站外包公司河南做网站的公司
  • 广州专业网站制作设计推广普通话手抄报模板
  • 抚顺市网站建设百度推广二级代理商
  • 盘龙区网站建设外包做网站公司
  • 地下城做解封任务的网站网站建设制作免费
  • 成都网站排名优化报价关键词在线查询
  • 最新企业网站模板seo建站营销
  • 河南做网站需要多少钱国内打开google网页的方法