javascript十個最常用的自定義函數(shù)

如果不使用類庫或者沒有自己的類庫泞莉,儲備一些常用函數(shù)總是有好處的。

(1)addEvent

網(wǎng)上最流行的版本是Scott Andrew的船殉,據(jù)說javascript界曾舉行一場比賽(此事件我們可以在Pro Javascript Techniques第100頁看到)或瀏覽PPK的網(wǎng)站鲫趁,征求添加事件與移除事件的函數(shù),他就是其獲獎?wù)呃妗O旅婢褪撬膶崿F(xiàn):

function addEvent(elm, evType, fn, useCapture) {
  if (elm.addEventListener) {
    elm.addEventListener(evType, fn, useCapture);//DOM2.0
    return true;
  }
  else if (elm.attachEvent) {
    var r = elm.attachEvent('on' + evType, fn);//IE5+
    return r;
  }
  else {
    elm['on' + evType] = fn;//DOM 0
  }
}

下面是Dean Edwards 的版本

// addEvent/removeEvent written by Dean Edwards, 2005
// with input from Tino Zijdel
// http://dean.edwards.name/weblog/2005/10/add-event/
function addEvent(element, type, handler) {
    //為每一個事件處理函數(shù)分派一個唯一的ID
    if (!handler.$$guid) handler.$$guid = addEvent.guid++;
    //為元素的事件類型創(chuàng)建一個哈希表
    if (!element.events) element.events = {};
    //為每一個"元素/事件"對創(chuàng)建一個事件處理程序的哈希表
    var handlers = element.events[type];
    if (!handlers) {
        handlers = element.events[type] = {};
        //存儲存在的事件處理函數(shù)(如果有)
        if (element["on" + type]) {
            handlers[0] = element["on" + type];
        }
    }
    //將事件處理函數(shù)存入哈希表
    handlers[handler.$$guid] = handler;
    //指派一個全局的事件處理函數(shù)來做所有的工作
    element["on" + type] = handleEvent;
};
//用來創(chuàng)建唯一的ID的計數(shù)器
addEvent.guid = 1;
function removeEvent(element, type, handler) {
    //從哈希表中刪除事件處理函數(shù)
    if (element.events && element.events[type]) {
        delete element.events[type][handler.$$guid];
    }//歡迎加入Java開發(fā)交流君樣:909038429
};
function handleEvent(event) {
    var returnValue = true;
    //抓獲事件對象(IE使用全局事件對象)
    event = event || fixEvent(window.event);
    //取得事件處理函數(shù)的哈希表的引用
    var handlers = this.events[event.type];
    //執(zhí)行每一個處理函數(shù)
    for (var i in handlers) {
        this.$$handleEvent = handlers[i];
        if (this.$$handleEvent(event) === false) {
            returnValue = false;
        }
    }
    return returnValue;
};
//為IE的事件對象添加一些“缺失的”函數(shù)
function fixEvent(event) {
    //添加標(biāo)準(zhǔn)的W3C方法
    event.preventDefault = fixEvent.preventDefault;
    event.stopPropagation = fixEvent.stopPropagation;
    return event;
};
fixEvent.preventDefault = function() {
    this.returnValue = false;
};
fixEvent.stopPropagation = function() {
    this.cancelBubble = true;
};

功能非常強悍挨厚,解決IE的this指向問題,event總是作為第一個參數(shù)傳入糠惫,跨瀏覽器就更不在話下互拾。

另九昧,我還珍藏了一個HTML5工作組的版本:

var addEvent=(function(){
    if(document.addEventListener){
        return function(el,type,fn){
            if(el.length){
                for(var i=0;i<el.length;i++){
                    addEvent(el[i],type,fn);
                }
            }else{
                el.addEventListener(type,fn,false);
            }
        };
    }else{
        return function(el,type,fn){
            if(el.length){
                for(var i=0;i<el.length;i++){
                    addEvent(el[i],type,fn);
                }
            }else{
                el.attachEvent('on'+type,function(){
                    return fn.call(el,window.event);
                });
            }
        };
    }
})();

(2)addLoadEvent()

我以前討論過這函數(shù),不細(xì)說违帆,就是慢了一點泊柬,各大類庫基本無視它叠萍,自行實現(xiàn)domReady版本夭禽。下面是Simon Willison 的實現(xiàn):

var addLoadEvent = function(fn) {
  var oldonload = window.onload;
  if (typeof window.onload != 'function') {
    window.onload = fn;
  }else {
    window.onload = function() {
      oldonload();
      fn();
    }
  }
}

(3) getElementsByClass()

我有收集癖贡茅,手頭上擁有許多版本,最后集思廣益自己實現(xiàn)了一個备燃。下面是我的實現(xiàn):

var getElementsByClassName = function (searchClass, node,tag) {
    if(document.getElementsByClassName){
        return  document.getElementsByClassName(searchClass)
    }else{//歡迎加入Java開發(fā)交流君樣:909038429
        node = node || document;
        tag = tag || "*";
        var classes = searchClass.split(" "),
        elements = (tag === "*" && node.all)? node.all : node.getElementsByTagName(tag),
        patterns = [],
        returnElements = [],
        current,
        match;
        var i = classes.length;
        while(--i >= 0){
            patterns.push(new RegExp("(^|\\s)" + classes[i] + "(\\s|$)"));
        }
        var j = elements.length;
        while(--j >= 0){
            current = elements[j];
            match = false;
            for(var k=0, kl=patterns.length; k<kl; k++){
                match = patterns[k].test(current.className);
                if (!match)  break;
            }
            if (match)  returnElements.push(current);
        }
        return returnElements;
    }
}

(4)cssQuery()

別名為getElementsBySeletor碉克,由Dean Edwards最先實現(xiàn),Prototype.js并齐,JQuery等類庫都有相應(yīng)實現(xiàn)棉胀,其中JQuery把它整合到$()選擇器中,名聲蓋過其前輩冀膝。不過IE8等新銳瀏覽器已經(jīng)實現(xiàn)querySelector與querySelectorAll方法,待到IE6與IE7報廢之日霎挟,它就無用了窝剖。無憂里有它的實現(xiàn)原理講解。由于太長酥夭,就不粘出來了赐纱,具體可到原作者網(wǎng)站看看脊奋。

(5)toggle()

用來顯示或隱藏一個DOM元素。

function toggle(obj) {
    var el = document.getElementById(obj);
    if ( el.style.display != 'none' ) {
        el.style.display = 'none';
    }
    else {
        el.style.display = '';
    }
}

(6)insertAfter()

DOM只提供了insertBefore疙描,我們很有必要自己實現(xiàn)insertAfter诚隙。不過我認(rèn)為 insertAdjacentElement是更好的選擇,現(xiàn)在除了火狐其他瀏覽器都實現(xiàn)這個方法起胰。下面是Jeremy Keith的版本:

function insertAfter(parent, node, referenceNode) {
    parent.insertBefore(node, referenceNode.nextSibling);
}

(7)inArray()

用于判斷檢查數(shù)組中是否存在某個值久又,下面方法取自Prototype類庫。

Array.prototype.inArray = function (value) {
    for (var i=0,l = this.length ; i <l ; i++) {
        if (this[i] === value) {
            return true;
        }
    }
    return false;
};

另一個版本:

var inArray = function (arr,value) {
    for (var i=0,l = arr.length ; i <l ; i++) {
        if (arr[i] === value) {
            return true;
        }
    }
    return false;
};

(8) getCookie(), setCookie(), deleteCookie()

做BBS與商業(yè)網(wǎng)站的應(yīng)該經(jīng)常用到效五,無理由每次都要讓用戶輸入密碼登錄吧地消。我們需要借助cookie實現(xiàn)自動登錄功能。

function getCookie( name ) {
    var start = document.cookie.indexOf( name + "=" );
    var len = start + name.length + 1;
    if ( ( !start ) && ( name != document.cookie.substring( 0, name.length ) ) ) {
        return null;
    }
    if ( start == -1 ) return null;
    var end = document.cookie.indexOf( ';', len );
    if ( end == -1 ) end = document.cookie.length;
    return unescape( document.cookie.substring( len, end ) );
}
function setCookie( name, value, expires, path, domain, secure ) {
    var today = new Date();
    today.setTime( today.getTime() );
    if ( expires ) {
        expires = expires * 1000 * 60 * 60 * 24;
    }
    var expires_date = new Date( today.getTime() + (expires) );
    document.cookie = name+'='+escape( value ) +
        ( ( expires ) ? ';expires='+expires_date.toGMTString() : '' ) + //expires.toGMTString()
        ( ( path ) ? ';path=' + path : '' ) +
        ( ( domain ) ? ';domain=' + domain : '' ) +
        ( ( secure ) ? ';secure' : '' );
}//歡迎加入Java開發(fā)交流君樣:909038429
function deleteCookie( name, path, domain ) {
    if ( getCookie( name ) ) document.cookie = name + '=' +
            ( ( path ) ? ';path=' + path : '') +
            ( ( domain ) ? ';domain=' + domain : '' ) +
            ';expires=Thu, 01-Jan-1970 00:00:01 GMT';
}

(9)getStyle()與setStyle()

所有UI控件都應(yīng)該存在的函數(shù)畏妖,動態(tài)設(shè)置樣式與獲取樣式脉执。這個可以寫得很短,也可以寫得很長戒劫,但要精確取得樣式半夷,一個字:難!但我發(fā)現(xiàn)許多問題都是發(fā)端于IE迅细,微軟的開發(fā)人員好像從來不打算給出getComputedStyle這樣的函數(shù)巫橄,與之相近的currentStyle會返回auto,inhert疯攒, ' '等讓你哭笑不得的值嗦随,這還沒有算上IE怪癖模式帶來的難度呢!各類庫的實現(xiàn)是非常長與難分離出來的敬尺,下面是我實現(xiàn)的版本:

function setStyle(el,prop,value){
   if(prop == "opacity" && !+"\v1"){
     //IE7 bug:filter 濾鏡要求 hasLayout=true 方可執(zhí)行(否則沒有效果)
     if (!el.currentStyle || !el.currentStyle.hasLayout) el.style.zoom = 1;
     prop = "filter";
     if(!!window.XDomainRequest){
       value ="progid:DXImageTransform.Microsoft.Alpha(style=0,opacity="+value*100+")";
     }else{
       value ="alpha(opacity="+value*100+")"
     }
   }
   el.style.cssText += ';' + (prop+":"+value);
 }
 
 function getStyle(el, style){
   if(!+"\v1"){
     style = style.replace(/\-(\w)/g, function(all, letter){
       return letter.toUpperCase();
     });
     return el.currentStyle[style];
   }else{
     return document.defaultView.getComputedStyle(el, null).getPropertyValue(style)
   }
 }

有關(guān)setStyle還可以看我另一篇博文枚尼,畢竟現(xiàn)在設(shè)置的樣式都是內(nèi)聯(lián)樣式,與html混雜在一起砂吞。

(10)$()

實至名歸署恍,最值錢的函數(shù),可以節(jié)省多少流量啊蜻直。最先由Prototype.js實現(xiàn)的盯质,那是洪荒時代遺留下來的珍獸,現(xiàn)在有許多變種概而。

function $() {
    var elements = [];
    for (var i = 0; i < arguments.length; i++) {
        var element = arguments[i];
        if (typeof element == 'string')
            element = document.getElementById(element);
        if (arguments.length == 1)
            return element;
        elements.push(element);
    }
    return elements;
}

image

最新2020整理收集的一些高頻面試題(都整理成文檔)呼巷,有很多干貨,包含mysql赎瑰,netty王悍,spring,線程餐曼,spring cloud压储、jvm鲜漩、源碼、算法等詳細(xì)講解集惋,也有詳細(xì)的學(xué)習(xí)規(guī)劃圖孕似,面試題整理等,需要獲取這些內(nèi)容的朋友請加Q君樣:909038429
/./*歡迎加入java交流Q君樣:909038429一起吹水聊天

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末刮刑,一起剝皮案震驚了整個濱河市喉祭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌为朋,老刑警劉巖臂拓,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異习寸,居然都是意外死亡胶惰,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進(jìn)店門霞溪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來孵滞,“玉大人,你說我怎么就攤上這事鸯匹》蝗模” “怎么了?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵殴蓬,是天一觀的道長匿级。 經(jīng)常有香客問我,道長染厅,這世上最難降的妖魔是什么痘绎? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮肖粮,結(jié)果婚禮上孤页,老公的妹妹穿的比我還像新娘。我一直安慰自己涩馆,他們只是感情好行施,可當(dāng)我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著魂那,像睡著了一般蛾号。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上涯雅,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天须教,我揣著相機(jī)與錄音,去河邊找鬼。 笑死轻腺,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的划乖。 我是一名探鬼主播贬养,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼琴庵!你這毒婦竟也來了误算?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤迷殿,失蹤者是張志新(化名)和其女友劉穎儿礼,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體庆寺,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡蚊夫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了懦尝。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片知纷。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖陵霉,靈堂內(nèi)的尸體忽然破棺而出琅轧,到底是詐尸還是另有隱情,我是刑警寧澤踊挠,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布乍桂,位于F島的核電站,受9級特大地震影響效床,放射性物質(zhì)發(fā)生泄漏睹酌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一扁凛、第九天 我趴在偏房一處隱蔽的房頂上張望忍疾。 院中可真熱鬧,春花似錦谨朝、人聲如沸卤妒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽则披。三九已至,卻和暖如春洗出,著一層夾襖步出監(jiān)牢的瞬間士复,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留阱洪,地道東北人便贵。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像冗荸,于是被迫代替她去往敵國和親承璃。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,927評論 2 355

推薦閱讀更多精彩內(nèi)容