JS 获取指定类别选择器的所以样式值
2012-11-21 14:07:47 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鎯у⒔閹虫捇鈥旈崘顏佸亾閿濆簼绨绘い鎺嬪灪閵囧嫰骞囬姣挎捇鏌熸笟鍨妞ゎ偅绮撳畷鍗炍旈埀顒勭嵁婵犲嫮纾介柛灞捐壘閳ь剛鎳撻~婵嬪Ω閳轰胶鐤呯紓浣割儐椤戞瑩宕ョ€n喗鐓曟い鎰靛亝缁舵氨绱撻崘鈺傜婵﹤顭峰畷鎺戔枎閹搭厽袦婵犵數濮崑鎾绘⒑椤掆偓缁夌敻骞嗛悙鍝勭婵烇綆鍓欐俊鑲╃磼閹邦収娈滈柡灞糕偓鎰佸悑閹肩补鈧尙鏁栧┑鐐村灦閹稿摜绮旈悽绋课﹂柛鏇ㄥ灠閸愨偓濡炪倖鍔﹀鈧繛宀婁邯濮婅櫣绱掑Ο璇茶敿闂佺ǹ娴烽弫璇差嚕婵犳碍鏅插璺猴工瀹撳棝姊虹紒妯哄缂佷焦鎸冲畷鎴﹀箻鐠囧弶宓嶅銈嗘尰缁嬫垶绂嶉悙顒佸弿婵☆垳鍘ф禍楣冩倵濮樼偓瀚�

/*
* 获取指定类别选择器的所以样式值
* @method getClassStyle
* @param {String} name 类别选择器的名字
* @param {Document} doc 指定的document
* @return {String} 该样式的cssText
*/
getClassStyle : function(name, doc) {
var doc = doc || document,
name2 = name.replace(/\./, '\\.').replace(/\b/,'\\b') + '\\b',
reg = new RegExp(name2, 'i');
ret = '';
for(var i=0; i<doc.styleSheets.length; i++) {
var styleSheet = document.styleSheets[i],
rules = styleSheet.cssRules ? styleSheet.cssRules : styleSheet.rules;
for(var j=0; j<rules.length; j++) {
var rule = rules[j],
cls = rule.selectorText;
// rule.selectorText可能不存在
if(cls && reg.test(cls)) {
var newStr = /{.*?}/.exec(rule.cssText) || '';
// 去重
if(-1 == ret.indexOf(newStr)) {
ret += newStr;
}
}
}
}
// 过滤掉大括号
return ret.replace(/{|}/g,'');
}
更多精彩
赞助商链接