欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript getElementsByClassName函數(shù)

 更新時(shí)間:2010年04月01日 18:09:00   作者:  
今天在腳本中應(yīng)用到了根據(jù)類(lèi)名取元素的方法,卻對(duì)其效率不甚滿(mǎn)意。于是,小幅修改了其探測(cè)元素類(lèi)名的方法,提升了約3成的效率.
今天在網(wǎng)上看到的一個(gè)根據(jù)ClassName獲取Elements的腳本,在此記錄一下,以便日后使用。
復(fù)制代碼 代碼如下:

var getElementsByClassName = function(searchClass, node, tag) {
if (document.getElementsByClassName) {
return document.getElementsByClassName(searchClass)
} else {
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;
}
}

下面是網(wǎng)上其它的一些相關(guān)介紹,大家可以一起參考下。

DOM中的getElementsByClassName解釋如下:DOM API 中提供3種方法取元素(getElementById,getElementsByName,getElementsByTagName),經(jīng)常編寫(xiě)CSS的人自然就會(huì)產(chǎn)生疑問(wèn),有沒(méi)有根據(jù)樣式類(lèi)名取元素的方法,可惜,DOM1/2 里面都沒(méi)有這樣的方法,prototype 很早就擴(kuò)展過(guò)DOM的方法,添加了 getElementsByClassName,從方法名上看,似乎非常正統(tǒng),與前面3種方法名稱(chēng)也像,分析其代碼,卻發(fā)現(xiàn)還是通過(guò) getElementsByTagName 來(lái)實(shí)現(xiàn)。這個(gè)方法稱(chēng)不上優(yōu)雅,因?yàn)樾枰闅v所有的元素,探測(cè)元素是否包含目標(biāo)樣式類(lèi)名,返回符合條件的元素?cái)?shù)組。google了一下,卻沒(méi)有找到更優(yōu)雅高效的替代方法。
復(fù)制代碼 代碼如下:

function getElementsByClassName(className, parentElement){
var elems = ($(parentElement)||document.body).getElementsByTagName("*");
var result=[];
for (i=0; j=elems[i]; i++){
if ((" "+j.className+" ").indexOf(" "+className+" ")!=-1){
result.push(j);
}
}
return result;
}

既然有g(shù)etElementsByClassName,一樣可以有 getElementsByAttribute(如:getElementsByValue、getElementsByStyle、getElementsByType)
復(fù)制代碼 代碼如下:

document.getElementsByClassName = function(className,oBox) {
//適用于獲取某個(gè)HTML區(qū)塊內(nèi)部含有某一特定className的所有HTML元素
this.d= oBox || document;
var children = this.d.getElementsByTagName('*') || document.all;
var elements = new Array();
for (var ii = 0; ii < children.length; ii++) {
var child = children[ii];
var classNames = child.className.split(' ');
for (var j = 0; j < classNames.length; j++) {
if (classNames[j] == className) {
elements.push(child);
break;
}
}
}
return elements;
}

document.getElementsByType = function(sTypeValue,oBox) {
//適用于獲取某個(gè)HTML區(qū)塊內(nèi)部同屬于某一特定type的所有HTML元素,如:input,script,link等等
this.d= oBox || document;
var children = this.d.getElementsByTagName('*') || document.all;
var elements = new Array();
for (var ii = 0; ii < children.length; ii++) {
if (children[ii].type == sTypeValue) {
elements.push(children[ii]);
}
}
return elements;
}

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

$Cls = function (s,o){
return document.getElementsByClassName(s,o);
};

$Type = function (s,o){
return document.getElementsByType(s,o);
};

$Tag = function (s,o){
this.d=o || document;
return this.d.getElementsByTagName(s);
};

$Name = function (s){ //通過(guò)name的方式只能針對(duì)整個(gè)document而言,不能為其限定范圍
return document.getElementsByName(s);
};

相關(guān)文章

  • javascript中的replace函數(shù)(帶注釋demo)

    javascript中的replace函數(shù)(帶注釋demo)

    在js中有兩個(gè)replace函數(shù) 一個(gè)是location.replace(url) 跳轉(zhuǎn)到一個(gè)新的url.一個(gè)string.replace("xx","yy") 替換字符串 返回一個(gè)新的字符串,該方法并不改變字符串本身。下面通過(guò)本文給大家介紹javascript中的replace函數(shù)
    2018-01-01
  • 整理Javascript事件響應(yīng)學(xué)習(xí)筆記

    整理Javascript事件響應(yīng)學(xué)習(xí)筆記

    整理Javascript事件響應(yīng)學(xué)習(xí)筆記,之前一系列的文章是跟我學(xué)習(xí)Javascript,本文就是進(jìn)一步學(xué)習(xí)javascript流程控制語(yǔ)句,希望大家繼續(xù)關(guān)注
    2015-12-12
  • 微信小程序接入vant Weapp組件的詳細(xì)步驟

    微信小程序接入vant Weapp組件的詳細(xì)步驟

    這篇文章主要介紹了微信小程序接入vant Weapp組件的詳細(xì)步驟,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • 微信小程序模板消息推送的兩種實(shí)現(xiàn)方式

    微信小程序模板消息推送的兩種實(shí)現(xiàn)方式

    這篇文章主要介紹了微信小程序模板消息推送的兩種實(shí)現(xiàn)方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • layui實(shí)現(xiàn)文件或圖片上傳記錄

    layui實(shí)現(xiàn)文件或圖片上傳記錄

    這篇文章主要為大家詳細(xì)介紹了layui實(shí)現(xiàn)文件或圖片上傳記錄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • js實(shí)現(xiàn)飛入星星特效代碼

    js實(shí)現(xiàn)飛入星星特效代碼

    這篇文章主要介紹了js實(shí)現(xiàn)飛入星星特效代碼,主要通過(guò)控制背景與飛入點(diǎn)的樣式,結(jié)合setTimeout函數(shù)即可實(shí)現(xiàn)星星飛入的效果,對(duì)于學(xué)習(xí)javascript有不錯(cuò)的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-10-10
  • js點(diǎn)擊按鈕實(shí)現(xiàn)圖片排序

    js點(diǎn)擊按鈕實(shí)現(xiàn)圖片排序

    這篇文章主要為大家詳細(xì)介紹了js點(diǎn)擊按鈕實(shí)現(xiàn)圖片排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 小程序云開(kāi)發(fā)初探(小結(jié))

    小程序云開(kāi)發(fā)初探(小結(jié))

    云開(kāi)發(fā)是微信平臺(tái)新開(kāi)放的功能,為開(kāi)發(fā)者提供集成了服務(wù)器,數(shù)據(jù)庫(kù)和資源存儲(chǔ)的云服務(wù)。這篇文章主要介紹了小程序云開(kāi)發(fā)初探(小結(jié)),感興趣的小伙伴們可以參考一下
    2018-10-10
  • 為什么JS中eval處理JSON數(shù)據(jù)要加括號(hào)

    為什么JS中eval處理JSON數(shù)據(jù)要加括號(hào)

    這篇文章主要介紹了為什么JS中eval處理JSON數(shù)據(jù)要加括號(hào)的相關(guān)資料,需要的朋友可以參考下
    2015-04-04
  • javascript模擬鼠標(biāo)點(diǎn)擊事件原理和實(shí)現(xiàn)方法

    javascript模擬鼠標(biāo)點(diǎn)擊事件原理和實(shí)現(xiàn)方法

    本文詳細(xì)介紹了JS模擬鼠標(biāo)點(diǎn)擊事件的原理以及應(yīng)用場(chǎng)景,并提供了模擬鼠標(biāo)左鍵點(diǎn)擊事件、右鍵點(diǎn)擊事件、滾輪事件和移動(dòng)事件的代碼實(shí)現(xiàn),了解JS模擬鼠標(biāo)點(diǎn)擊事件的原理和實(shí)現(xiàn)方法對(duì)于開(kāi)發(fā)人員非常重要,這對(duì)于許多面向用戶(hù)的web應(yīng)用程序的開(kāi)發(fā)和測(cè)試都具有很重要的意義
    2023-09-09

最新評(píng)論