当前位置: 首页 > 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.mmbaike.com/news/29661.html

相关文章:

  • 连云港 网站 建设实时热点新闻事件
  • 做软装有什么网站找图片关于手机的软文营销
  • 平潭做网站百度竞价广告点击器
  • 东莞市城乡和住房建设局杭州排名优化软件
  • wordpress网站监测如何去推广自己的产品
  • 上海公司注册流程及费用泰州seo推广公司
  • 官网网站建设余姚网站制作公司
  • 国内工业设计网站百度平台推广的营销收费模式
  • 微信连接微网站如何提升百度关键词排名
  • 网站备案为什么这么慢seo与sem的关系
  • 丽江做网站网页搜索优化seo
  • 用muse做网站seo网站关键词快速排名
  • 网站开发项目流程图模板百度推广要多少钱
  • 精湛的网站设计武汉seo百度
  • 网站开发会用到的框架icp备案查询官网
  • 开封做网站睿艺美百度学术官网入口
  • 世界杯网站建设做网站
  • 采购网站官网seo怎么收费的
  • 凡科做网站怎么样网站内部链接优化方法
  • 广东佛山今日最新通告东莞网络优化公司
  • vs2017 做c 网站自助建站系统
  • 网站备案号怎么看软文推广哪个平台好
  • 怎么判断网站有没有做百度商桥培训报名
  • 北京智联招聘官方网站做家政3322免费域名注册
  • 网站现在一般做多大尺寸北京网站优化托管
  • 专门做qq小工具的网站站长工具之家seo查询
  • 域名跟空间都有了怎么做网站百度最新推广产品
  • 网站项目如何做需求分析在线磁力搜索神器
  • 适合代码新手做的网站无限制搜索引擎排名
  • 企业网站托管注意事项网站推广软件有哪些