js组件之间的通信

应用场景:

1.在刷微博的时候,滑到某个头像上,会出现一张usercard(用户名片), 微博列表区有这个usercard, 推荐列表也有这个usercard,评论区也有。

2.在网上购物时,购物车安静的停留在页面的角落里,不声不响。你在页面上买了零食买了书,购物车还是安静的呆着,猛然间点开一看,安静的购物车已经躺满了。

以上两种,在模块化满天飞的今天,当然不可能面向过程的一一开发,你不能在微博列表,微博推荐和评论中逐一把用户名片功能开发一遍。实际上,常见

的做法是将usercard作为一个组件,当然,comment也是一个组件。购物车也是一个组件。怎么可以做到鼠标放到评论和回复的用户头像上显示名片呢?这里就涉及到了组件之间互相通信的机制。

组件的通信方法有多种,API 观察者 都可以。最好的方案我认为是使用事件机制。

所有组件之间可以通过一个叫eventbus通用组件进行信息的交互。

1. 在usercard组件中,可以监听 eventbus 的一个 usercard:show 事件。

2. 在需要展示usercard的组件中,可以触发eventbus的这个事件,必要的话传入对应的参数。

其实之前的时候也经常接触这样的用法,这次从一个博客中看到,就有了自己动手写的想法,一写之下发现也很简单,不知道是不是还有很多自己目前没想到的,先记录下来。

先看下这个事件机制组件(AMD规范下的代码)

define(function (require) {
    var config = {};

    // 用于事件的存储;
    config.eventList = {};

    /*
    * 事件定义
    * @param {string} 事件的名称;
    * @param {function} function
     */
    config.on = function (name, func) {
        var me = this;
        if (!me.eventList[name]) {
            me.eventList[name] = func;
        }
        else {
            alert(‘这个方法名已经被用过了,请换一个名字‘);
        }
    };

    /*
    * 事件触发
    *@param {string} 事件名称;
    *@param {obj} 事件中的参数
     */
    config.emit = function (name, data) {
        var me = this;
        if (me.eventList[name]) {
            me.eventList[name](data);
        }
        else {
            alert(‘没有找到对应的方法‘);
        }
    };

    return config;
});

一个是定义,一个是触发。看起来很简单的样子。现在写两个组件来试一下吧

第一个组件,usercard,需要在这里定义 usercard:show事件。

define(function (require) {
    var eventBus = require(‘eventBus‘);
    var config = {};

    config.add = function () {
        var obj = {
            name: ‘usercard‘,
            type: ‘mouseover‘
        };
       // 这里定义eventbus的事件
        eventBus.on(‘usercard:show‘, function (data) {
            obj = $.extend(obj, data);
            data.node.title = data.sid;
            data.node.style.backgroundColor = ‘red‘;
        });
    };

    return config;
})

再写一个组件 comment 用于触发eventbus的

define(function (require) {
    var eventBut = require(‘eventBut‘);
    var config = {};

    var DomEvent = {

    };

    function domEvents() {
        $("#commentList").delegate(‘dt‘, ‘click‘, function (e) {
            var target = e.target;
            var sid = target.getAttribute(‘sid‘);
           // 触发事件
            eventBut.emit(‘usercard:show‘,{
                sid: sid,
                node: target
            });
        });
    }

    config.init = function () {
        domEvents();
    }

    return config;

});

写一个页面 来加载

<script>
    require([‘comment‘, ‘userCard‘], function (comment, usercard) {
        usercard.add();
        comment.init();
    })
</script>

测试了一下 是可以的~~

时间: 2024-11-10 15:37:24

js组件之间的通信的相关文章

Vue.js组件之间的通信

导语:组件之间的关系不外乎两种, 父子组件和非父子组件,本文将对两类组件之间的通信方式进行详细阐述. 父子组件间的通信 通信方式1(单向绑定): Props down, Events up (建议使用) Props down, Events up 是指 使用props向子组件传递数据,父组件属性发生变化时,子组件可实时更新视图:子组件发生变化,可以使用$emit发送事件消息,以此向父组件传递变化消息. props 是单向的,当父组件的属性变化时,将传递给子组件,但子组件中的props属性变化不会

组件之间的通信(子组件-改变父组件的值)

在vue中,组件之间的通信,是不建议子组件改变父组件的值,因为一个父组件有可能会有很多子组件,改来改去会很难管理(别人都这样说,我信) 试试: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src='../vue.js'> </script> </head> <bod

vue2.0嵌套组件之间的通信($refs,props,$emit)

vue的一大特色就是组件化,所以组件之间的数据交互是非常重要,而我们经常使用组件之间的通信的方法有:props,$refs和emit. 初识组件之间的通信的属性和方法 props的使用 子组件使用父组件的数据,使用vue的属性props. 当我们在父组件parent里面嵌套一个子组件son的时候,如果我们需要使用父组件的数据的时候,我们可以在子组件标签上面绑定一个属性,然后在子组件里面通过props来调用这个属性,就可以使用这个数据了. //父组件 <sonPart :list="list

vue.js 组件之间如何实现数据传递?

组件是 vue.js  最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用.如何传递数据也成了组件的重要知识点之一.本文和大家分享的就是vue.js  组件之间传递数据相关内容,一起来看看吧,希望对大家 学习vue.js有所帮助. 组件 组件与组件之间,还存在着不同的关系.父子关系与兄弟关系(不是父子的都暂称为兄弟吧). 父子组件 父子关系即是组件 A  在它的模板中使用了组件  B ,那么组件  A  就是父组件,组件  B  就是子组件. //  注册

React 组件基本使用(3) ---父子组件之间的通信

当有多个组件需要共享状态的时候,这就需要把状态放到这些组件共有的父组件中,相应地,这些组件就变成了子组件,从而涉及到父子组件之间的通信.父组件通过props 给子组件传递数据,子组件则是通过调用父组件传给它的函数给父组件传递数据. 很简单的一个例子,我们在输入框中输入温度,输入框下面显示冷和热.这里就有两个组件,输入框和它下面的显示内容,且它们共享一个状态,就是温度.所以我们要把温度这个状态放到这两个组件的父组件中.这里就有三个组件,一个输入框TemperatureInput,  一个是显示内容

react native 之子组件和父组件之间的通信

react native开发中,为了封装性经常需要自定义组件,这样就会出现父组件和子组件,那么怎么在父组件和子组件之间相互通信呢,也就是怎么在各自界面push和pop.传值. 父组件传递给子组件: 父组件: 在主组件里面,使用通过写一个子组件的属性,直接把值或者navigator传给子组件即可.如下20行: 1 /** 2 * Sample React Native App 3 * https://github.com/facebook/react-native 4 * 父组件传递给子组件 5

McAfee Vulnerability Manager(Foundstone)各组件之间的通信关系

Components andwhat they do McAfeeVulnerability Manager consists of components that work together to monitor yoursystems. Enterprise manager – Uses Microsoft Internet Information Services (IIS) to provideauthorized users with access to McAfee Vulnerab

使用Broadcast实现android组件之间的通信

android组件之间的通信有多种实现方式.Broadcast就是当中一种. 在activity和fragment之间的通信,broadcast用的很多其它本文以一个activity为例. 效果如图: 布局文件: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" andro

react 实现组件嵌套以及子组件与父组件之间的通信

当子组件触发onChange事件时,实际调用的是父组件中的handelSelect函数,通俗来说就是父组件通过属性handleSelect实现与子组件之间的通信. 父组件:SignupForm 子组件:GenderSelect 渲染: