zoukankan      html  css  js  c++  java
  • JQuery最佳实践:JQuery自定义事件的应用

    本文主要介绍JQuery框架里面支持的自定义事件模型,通过实例说明什么时候可以利用事件模型进行面向对象的JS编程,以及利用“带命名空间的事件处理函数”来避免unbind时影响别的事件订阅。

    知识要点:

    1,自定义事件custom events及事件的订阅

    2,trigger、bind、unbind方法的使用

    3,带命名空间的自定义事件

    将下面内容粘贴至txt文档后再直接粘贴至firebug的控制台,运行看看。

    /*
    JQuery自定义事件的应用-Javascript OO
    有一帅哥叫Levin,在某公司前端设计部工作,他的主管是大帅哥A,经理是大美眉B。
    领导们希望可以抽空瞄瞄这家伙每周的工作情况,于是。。。
    Levin每周一要用google doc写一份关于上周工作的总结,并被要求写完后要MSN通知A和B。。。
    Levin非常乐意做周总结,但是他提出了一个建议:
    既然我用google doc写好了,你们喜欢看便用google reader订阅我的文档更新吧,我不喜欢用微软的MSN。。。

    这丫...A和B头顶乌鸦飘了几秒,但欣然答应。
    */

    //这个是Levin同学
     

    var Levin={name:"Levin"};
    Levin
    =$(Levin);


    //每周要写周总结

    Levin.bind("evt_weeklyReport",function(evt){
    alert(
    this.name+"高呼:Yeah!周总结已经写好啦.");
    });

    //主管A
    var A={name:"帅哥A"};

    //他要订阅Levin的周总结
    A.rssLevin=function(){
    Levin.bind(
    "evt_weeklyReport.fromA",function(evt,data){
    alert(A.name
    +":嗯,不错,Levin还是挺积极的嘛!");
    })
    };
    A.rssLevin();

    //经理B
    var B={name:"美眉B"};

     
    //她也订阅Levin的周总结

    B.rssLevin=function(){
    Levin.bind(
    "evt_weeklyReport.fromB",function(evt,data){
    alert(B.name
    +":周总结呆会看,先看看他说的那个网站");
    window.location
    =evt.site;
    })
    };
    B.rssLevin();

    //每次Levin同学写好周总结后便会用google doc发布一下
     

    Levin.trigger({type:"evt_weeklyReport",site:"http://vivasky.com"});

    //经理B突然有一天去搜狐做了,不再订阅Levin的周结...
     

    B.unRssLevin=function(){
    alert(
    "我要去搜狐做副总裁啦,哈哈");
    Levin.unbind(
    "evt_weeklyReport.fromB");
    return true;
    }();
     

    //尽管B跳槽了,周总结还是要按时发布的。。。
    Levin.trigger({type:"evt_weeklyReport",site:"http://vivasky.com"});

    ---------华丽的分隔线---------- 
     

    活得出色点

    Levin

    http://vivasky.com

    作者:Mamboer
  • 相关阅读:
    jquery中 append 和appendto的区别
    vb的property 和event
    VB 基础语法以及教学视频
    outlook 2007 IMAP设置和配置
    浏览器文档播放Shockwave Flash 插件问题
    VB execl文件后台代码,基础语法
    VB中后台打开Excel文件实现代码
    excel文件后台代码
    DataTable中执行DataTable.Select("条件"),
    多个不同的表合并到一个datatable中,repeater在绑定datatable
  • 原文地址:https://www.cnblogs.com/scy251147/p/1824729.html
Copyright © 2011-2022 走看看