Vue EventBus自定义组件事件传递
前言组件化应用构建是Vue的特点之一,因此我们在Vue的实际开发过程中会经常需要封装自定义组件,以提高开发的效率。 而组件在大部分情况下并不会孤立的存在,它必然会与父组件和兄弟组件产生数据的交互。所以在这里为大家总结两种组件数据交互的方式:EventBus和利用Vuex框架进行状态管理。 我会通过两种不同的交互方式,它们对于父子组件间数据交互和兄弟组件间数据交互。 由于篇幅关系,本文主要介绍EventBus进行数据消息传递;关于运用Vuex框架进行状态管理在下一篇文章中介绍。 案例介绍本章节会有大量的代码示例,为了让读者阅读轻松,做如下目录和组件介绍。本章节主要运用了两个子组件和一个父组件。 子组件文件名: SearchInput.vue和SearchItem.vue父组件文件名: StateView.vue目录结构展示:1、SearchInput.vue组件介绍:一个输入框,它会onInput方法去监听输入内容,并调用方法,将输入框内的数据传递出去。 代码展示: <script type="text/ecmascript-6"> } <style lang="stylus" rel="stylesheet/stylus"> SearchItem.vue 组件介绍:一个span,它主要用来接收父组件传递的内容和接收同胞组件输入框传递的内容,并进行展示。 代码示例: <script type="text/ecmascript-6"> <style lang="stylus" rel="stylesheet/stylus"> StateView.vue 组件介绍:父组件,主要展示页面和加载子组件 代码示例: {{content}}
<script type="text/ecmascript-6"> export default{ <style lang="stylus" rel="stylesheet/stylus"> 正文EventBus1、父组件发送数据给子组件,可以通过子组件定义的 2、EventBus其实就是通过实例化一个Vue实例,然后通过该实例的 我们看下一个下面案例主要展示了:1、通过 2、子组件(SearchInput)通过 目录结构展示效果展示代码展示:(粗体表示变化部分)1、第一步:自定义一个EventBus(SearchEvent.js)在这里我们 第二步:子组件通过EventBus发送数据消息<script type="text/ecmascript-6">
} <style lang="stylus" rel="stylesheet/stylus"> 在上面的示例我们主要做了以下事情: 1、导入EventBus 2、通过 第三步父组件(StateView)和子组件(SearchItem)接收数据消息StateView.vue {{content}}
<script type="text/ecmascript-6">
<style lang="stylus" rel="stylesheet/stylus"> 在上面的示例我们主要做了以下事情: 1、在父组件,我们通过SearchItem的 2、通过在组件 SearchItem.vue <script type="text/ecmascript-6">
<style lang="stylus" rel="stylesheet/stylus"> 在上面的示例我们主要做了一事情: 通过在组件 我们可以感受到 SearchInput一发送数据消息,所有注册接收 复盘:1、父组件给子组件进行数据传递可以通过 2、子组件给父组件进行消息传递或子组件给兄弟组件进行消息传递可以通过EventBus去实例化一个Vue,并通过该实例的 3、数据消息一旦发送,所有注册了接收该数据消息的地方都会接收到该数据消息。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |