首页 > 编程语言 > 详细

JavaScript Patterns 4.7 Init-Time Branching

时间:2014-06-18 22:35:28      阅读:468      评论:0      收藏:0      [点我收藏+]

When you know that a certain condition will not change throughout the life of the program, it makes sense to test the condition only once. Browser sniffing (or feature detection) is a typical example.

// BEFORE

var utils = {

    addListener : function(el, type, fn) {

        if ( typeof window.addEventListener === ‘function‘) {

            el.addEventListener(type, fn, false);

        } else if ( typeof document.attachEvent === ‘function‘) {// IE

            el.attachEvent(‘on‘ + type, fn);

        } else {// older browsers

            el[‘on‘ + type] = fn;

        }

    },

    removeListener : function(el, type, fn) {

        // pretty much the same...

    }
};

// AFTER

// the interface

var utils = {

    addListener : null,

    removeListener : null

};

// the implementation

if ( typeof window.addEventListener === ‘function‘) {

    utils.addListener = function(el, type, fn) {

        el.addEventListener(type, fn, false);

    };

    utils.removeListener = function(el, type, fn) {

        el.removeEventListener(type, fn, false);

    };

} else if ( typeof document.attachEvent === ‘function‘) {// IE

    utils.addListener = function(el, type, fn) {

        el.attachEvent(‘on‘ + type, fn);

    };

    utils.removeListener = function(el, type, fn) {

        el.detachEvent(‘on‘ + type, fn);

    };

} else {// older browsers

    utils.addListener = function(el, type, fn) {

        el[‘on‘ + type] = fn;

    };

    utils.removeListener = function(el, type, fn) {

        el[‘on‘ + type] = null;

    };

}

JavaScript Patterns 4.7 Init-Time Branching,布布扣,bubuko.com

JavaScript Patterns 4.7 Init-Time Branching

原文:http://www.cnblogs.com/haokaibo/p/Init-Time-Branching.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!