[js高手之路]Vue2.0基于vue-cli+webpack同级组件…
2018-06-24 00:13:49来源:未知 阅读 ()
我们接着上文继续,本文我们讲解兄弟组件的通信,项目结构还是跟上文一样.
在src/assets目录下建立文件EventHandler.js,该文件的作用在于给同级组件之间传递事件
EventHandler.js代码:
1 import Vue from 'Vue'; 2 export default new Vue();
2,在Components目录下新建一个组件Brother1.vue
1 <template> 2 <div> 3 <h3>Z国: ghostwu</h3> 4 <input v-on:click="send" type="button" value="发送"> 5 <p>{{msg}}</p> 6 </div> 7 </template> 8 <script> 9 import EventHandler from '../assets/EventHandler.js'; 10 export default { 11 data(){ 12 return { 13 msg : '' 14 } 15 }, 16 methods : { 17 send(){ 18 EventHandler.$emit( 'myDefineEv', "ghostwu向岛国发射了一颗原子弹" ); 19 } 20 }, 21 mounted (){ 22 let _this = this; 23 EventHandler.$on( "RDefineEv", function( data ){ 24 _this.msg = data; 25 } ); 26 } 27 } 28 </script>
。通过EventHandler.$emit发送一个自定义事件myDefineEv
。通过mouted【相当于jquery的ready, 原生js的onload】,这个是vue生命周期的钩子函数, 用于在页面加载完成之后执行代码,在这里就是接收RDefineEv事件( Brother2.vue定义的 )
2,在Components目录下新建一个组件Brother2.vue
1 <template> 2 <div> 3 <h3>R国:八嘎</h3> 4 {{msg}} 5 <input v-on:click="defend" type="button" value="防御"> 6 </div> 7 </template> 8 <script> 9 import EventHandler from '../assets/EventHandler.js'; 10 export default { 11 data(){ 12 return { 13 msg : '' 14 } 15 }, 16 methods : { 17 defend(){ 18 EventHandler.$emit( 'RDefineEv', "岛国采用了高科技反原子弹系统" ); 19 } 20 }, 21 mounted(){ 22 let _this = this; 23 EventHandler.$on( "myDefineEv", function( data ){ 24 _this.msg = data; 25 } ); 26 } 27 } 28 </script>
。点击按钮发送RDefineEv事件
。文档ready的时候,接收myDefineEv(Brother1.vue)出发的自定义事件
三、在App.vue中调用两个同级组件
1 <template> 2 <div id="app"> 3 <Brother1></Brother1> 4 <Brother2></Brother2> 5 </div> 6 </template> 7 8 <script> 9 import Brother1 from './components/Brother1.vue'; 10 import Brother2 from './components/Brother2.vue'; 11 12 export default { 13 components : { 14 Brother1, 15 Brother2 16 } 17 } 18 </script>
小结:
- 创建一个事件传递中心,例如EventHandler.js,用它作为传递消息的中介
- 在需要传值的组件中用EventHandler.$emit触发一个自定义事件,并传递参数
- 在需要接收数据的组件中用EventHandler.$on监听自定义事件,并在回调函数中处理传递过来的参数
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Markdown(editormd)语法解析成HTML
下一篇:void运算符
- Vue学习之路由vue-router传参及嵌套小结(十) 2019-08-14
- Vue学习之路由vue-router小结(九) 2019-08-14
- html.css.javascript 跟随着我一起走向前端之路 2019-05-22
- 一个「学渣」从零开始的Web前端自学之路 2019-02-20
- js 学习之路10:try异常处理和第一个js小程序 2019-02-17
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash