国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

一個cssQuery對象 javascript腳本實現代碼

2019-11-21 01:15:32
字體:
來源:轉載
供稿:網友
復制代碼 代碼如下:

/**
* @author Supersha
* @QQ:770104121
*/
var cssQuery = {
//parent:用于存儲當前節點的父節點的引用
parent: document,
select: function(selectorStr){
var selectors=selectorStr.split(" "); //分隔字符串
for (var i = 0, len = selectors.length; i < len; i++) {
var el = this.parent || document; //用于存儲指定class屬性的節點引用
var val=this.replaceStr(selectors[i]); //代替掉"#"和"."點號,用于獲取指定的ID的節點引用
if (selectors.length == 1) { //如果只有一個參數
if (!(/[#.]/g).test(selectors[i])) { //如果是HTML標簽
return document.getElementsByTagName(selectors[i]);
}
else { //如果是ID或者指定的class值
//判斷是ID還是class屬性
return (this.IDLabel(selectors[i])) ? this.$(val) : this.getElementsByClassName(document, "*", val);
}
}
//如果達到selectorStr字符號中最后的那個ID或者class或者HTML標簽
else if(i == selectors.length-1){
if (!(/[#.]/g).test(selectors[i])) { //如果是HTML標簽
return el.getElementsByTagName(selectors[i]);
}
else { //如果是ID或者class屬性
return (this.IDLabel(selectors[i])) ? this.$(val) : this.getElementsByClassName(el,"*",val);
}
}
else{ //如果存在兩級以上的selectorStr,則存儲當前節點的引用到parent屬性中
if (!(/[#.]/g).test(selectors[i])) { //如果是HTML標簽
this.parent = el.getElementsByTagName(selectors[i])[0];
}
else { //如果是ID或者class屬性
this.parent = ((/#/gi).test(selectors[i])) ? this.$(val) : el;
}
}
}
},
$: function(id){ //用于得到指定ID的引用
return document.getElementById(id);
},
IDLabel: function(selector){ //判斷是否是ID屬性
return ((/#/gi).test(selector)) ? true : false;
},
classLabel: function(selector){ //判斷是否是class屬性
return ((//./gi).test(selector)) ? true : false;
},
replaceStr:function(a){ //替換掉"#"和"."點號,用于獲取指定的ID的節點引用
return a.replace("#","").replace(".","");
},
getElementsByClassName: function(el, tag, classname){ //通過class屬性值獲取含有class屬性值的元素的引用
var elem = el || document;
if (!classname)
return;
tag = tag || "*";
var allTagsDom = ((tag == "*") && (elem.all)) ? elem.all : elem.getElementsByTagName(tag);
classname = classname.replace(//-/g, "http://-");
var regex = new RegExp("(^|//s*)" + classname + "(//s*|$)");
var matchElements = new Array();
var element;
for (var i = 0; i < allTagsDom.length; i++) {
element = allTagsDom[i];
if (regex.test(element.className)) { //根據正則來檢測類名
matchElements.push(element);
}
}
return matchElements;
}
}
//調用方法:cssQuery.select(selectorString); selectorString 像這種:"#p #b .em",
//可以接收HTML標簽和ID、class的組合,返回指定的selectorString的引用
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 西充县| 夏河县| 曲沃县| 宜宾县| 泸水县| 台东县| 汶上县| 天祝| 英超| 沅江市| 临泉县| 云霄县| 南昌县| 黑山县| 河东区| 马尔康县| 杭州市| 上杭县| 富锦市| 八宿县| 东平县| 宣化县| 泰顺县| 福州市| 永平县| 禹州市| 盐边县| 福海县| 苏尼特右旗| 阿勒泰市| 新津县| 嘉黎县| 聂拉木县| 搜索| 留坝县| 金湖县| 隆昌县| 呼和浩特市| 德钦县| 嘉鱼县| 合山市|