您好,欢迎访问一九零五行业门户网

JavaScript中自定义事件用法分析_javascript技巧

本文实例讲述了javascript中自定义事件用法。分享给大家供大家参考。具体分析如下:
在web前端开发中,很多人可能不会用到js的自定义事件,但如果是做一个相对来说比较大的项目,尤其是多人协同开发的时候,自定义事件就显得很重要了。那么,什么是js中的自定义事件呢?我们先来看一个例子:
前端开发员a封装了一个函数:
复制代码 代码如下:
function move(){
    alert(a);  //以此来代表n行代码
}
过段时间,前端开发员b要在a的基础上丰富这个函数,于是,他会这样写:
复制代码 代码如下:
function move(){
    alert(a);  //以此来代表n行代码
    alert(b);  //以此来代表n行代码
}
是不是发现了问题,b要注意和a的变量、函数等等的命名和冲突问题,又过段时间,前端开发员c也要丰富这个函数,于是:
复制代码 代码如下:
function move(){
    alert(a);  //以此来代表n行代码
    alert(b);  //以此来代表n行代码
    alert(c);  //以此来代表n行代码
}
这时候会很令人抓狂了,c写起代码来我敢肯定不会很轻松。解决这个问题的方法就是通过自定义事件,我们知道一个元素身上可以添加相同的事件而不会各自影响,如:
复制代码 代码如下:
window.addeventlistener('click',function(){
    alert(1);
} ,false);
window.addeventlistener('click',function(){
    alert(2);
} ,false);
点击页面的时候,1和2都会弹出,那么我们就可以用这种方法来定义我们的函数:
复制代码 代码如下:
window.addeventlistener('move',function(){
    alert(3);
} ,false);
window.addeventlistener('move',function(){
    alert(4);
} ,false);
这样,我们执行move();的时候就会弹出3和4,这里的move就是自定义事件,它其实就是一个函数下面看看如何给事件处理程序传递参数:
复制代码 代码如下:
//将有参数的函数封装为无参数的函数
function createfunction(obj, strfunc) {
    var args = [];       //定义args 用于存储传递给事件处理程序的参数
    if (!obj) obj = window; //如果是全局函数则obj=window;
    //得到传递给事件处理程序的参数
    for (var i = 2; i     //用无参数函数封装事件处理程序的调用
    return function() {
        obj[strfunc].apply(obj, args); //将参数传递给指定的事件处理程序
    }
}
function class1() {
}
class1.prototype = {
    show: function() {
        this.onshow();
    },
    onshow: function() { }
}
function objonshow(username) {
    alert(hello, + username);
}
function test() {
    var obj = new class1();
    var username = test;
    obj.onshow = createfunction(null, objonshow, username);
    obj.show();
}
因为事件机制仅传递一个函数的名称,不带有任何参数的信息,所以无法传递参数进去,这是后话了,“要解决这个问题,可以从相反的思路去考虑,不考虑怎么把参数传进去,而是考虑如何构建一个无需参数的事件处理程序,该程序是根据有参数的事件处理程序创建的,是一个外层的封装。”,这里的“该程序”就是createfunction函数,它巧妙地利用apply函数将带参数的函数封装为无参数函数。最后我们看看如何实现自定义事件的多绑定:
复制代码 代码如下:
// 使自定义事件支持多绑定
//将有参数的函数封装为无参数的函数
function createfunction(obj, strfunc) {
    var args = [];       //定义args 用于存储传递给事件处理程序的参数
    if (!obj) obj = window; //如果是全局函数则obj=window;
    //得到传递给事件处理程序的参数
    for (var i = 2; i     //用无参数函数封装事件处理程序的调用
    return function() {
        obj[strfunc].apply(obj, args); //将参数传递给指定的事件处理程序
    }
}
function class1() {
}
class1.prototype = {
    show: function() {
        if (this.onshow) {
            for (var i = 0; i                 this.onshow[i]();
            }
        }
    },
    attachonshow: function(_ehandler) {
        if (!this.onshow) { this.onshow = []; }
        this.onshow.push(_ehandler);
    }
}
function objonshow(username) {
    alert(hello, + username);
}
function objonshow2(testname) {
    alert(show: + testname);
}
function test() {
    var obj = new class1();
    var username = your name;
    obj.attachonshow(createfunction(null, objonshow, username));
    obj.attachonshow(createfunction(null, objonshow2, test message));
    obj.show();
}
我们看到,attachonshow方法实现的基本思想是对数组的push操作,其实我们还可以在事件执行完成之后,移除事件处理函数,下面单独实现:
复制代码 代码如下:
//将有参数的函数封装为无参数的函数
function createfunction(obj, strfunc) {
    var args = [];       //定义args 用于存储传递给事件处理程序的参数
    if (!obj) obj = window; //如果是全局函数则obj=window;
    //得到传递给事件处理程序的参数
    for (var i = 2; i     //用无参数函数封装事件处理程序的调用
    return function() {
        obj[strfunc].apply(obj, args); //将参数传递给指定的事件处理程序
    }
}
function class1() {
}
class1.prototype = {
    show: function() {
        if (this.onshow) {
            for (var i = 0; i                 this.onshow[i]();
            }
        }
    },
    attachonshow: function(_ehandler) { // 附加事件
        if (!this.onshow) { this.onshow = []; }
        this.onshow.push(_ehandler);
    },
    detachonshow: function(_ehandler) { // 移除事件
        if (!this.onshow) { this.onshow = []; }
        this.onshow.pop(_ehandler);
    }
}function objonshow(username) {
    alert(hello, + username);
}
function objonshow2(testname) {
    alert(show: + testname);
}
function test() {
    var obj = new class1();
    var username = your name;
    obj.attachonshow(createfunction(null, objonshow, username));
    obj.attachonshow(createfunction(null, objonshow2, test message));
    obj.show();
    obj.detachonshow(createfunction(null, objonshow, username));
    obj.show(); // 移除一个,显示剩余的一个
    obj.detachonshow(createfunction(null, objonshow2, test message));
    obj.show(); // 两个都移除,一个也不显示
}
希望本文所述对大家的javascript程序设计有所帮助。
其它类似信息

推荐信息