前端-vue基础63-非父子组件传值
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <div id="app"> <div>父组件</div> <test-tom></test-tom> <test-jerry></test-jerry> </div> <script type="text/javascript" src="./js/vue.js"></script> <script> //提供事件中心 var hub = new Vue(); Vue.component('test-tom', { data: function() { return { num: 0 } }, template: `<div>TOM:{{num}} <div><button @click='handle'>点击</button></div></div>`, methods: { handle: function() { //触发兄弟事件 hub.$emit('jerry-event', 1); } }, mounted: function() { hub.$on('tom-event', (val) => { this.num += val; }); } }); Vue.component('test-jerry', { data: function() { return { num: 0 } }, template: `<div>JERRY:{{num}} <div><button @click='handle'>点击</button></div></div>`, methods: { handle: function() { hub.$emit('tom-event', 2); } }, mounted: function() { hub.$on('jerry-event', (val) => { this.num += val; }); } }) var vm = new Vue({ el: '#app', data: { }, }) </script> </body> </html>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通