刚刚看了下jQuery的源代码,其中关于CSS及className的操作思想确实很不错,值得借鉴。 其中关于jQuery.className.has的定义部分,是用的正则来实现的,其实此处直接利用Javascript中String对象的indexOf方法来作处理的话,比用正则效率会更些,因此复制代码 代码如下: jQuery.className.has的定义可以改进成: has: function( t, c ) { t = t.className || t; t = " " + t + " "; c = " " + c + " "; return t.indexOf(c)>-1; }
原代码中关于CSS及className的操作部分节选如下: 复制代码 代码如下: className: { // internal only, use addClass("class") add: function( elem, c ){ jQuery.each( c.split(/s+/), function(i, cur){ if ( !jQuery.className.has( elem.className, cur ) ) elem.className += ( elem.className ? " " : "" ) + cur; }); },
// internal only, use removeClass("class") remove: function( elem, c ){ elem.className = c ? jQuery.grep( elem.className.split(/s+/), function(cur){ return !jQuery.className.has( c, cur ); }).join(" ") : ""; },
// internal only, use is(".class") has: function( t, c ) { t = t.className || t; // escape regex characters c = c.replace(/([.\+*?[^]$(){}=!<>|:])/g, "\$1"); return t && new RegExp("(^|\s)" + c + "(\s|$)").test( t ); } }, swap: function(e,o,f) { for ( var i in o ) { e.style["old"+i] = e.style[i]; e.style[i] = o[i]; } f.apply( e, [] ); for ( var i in o ) e.style[i] = e.style["old"+i]; },
css: function(e,p) { if ( p == "height" || p == "width" ) { var old = {}, oHeight, oWidth, d = ["Top","Bottom","Right","Left"];
prop = prop.replace(/([A-Z])/g,"-$1").toLowerCase(); var cur = document.defaultView.getComputedStyle(elem, null);
if ( cur ) ret = cur.getPropertyValue(prop); else if ( prop == "display" ) ret = "none"; else jQuery.swap(elem, { display: "block" }, function() { var c = document.defaultView.getComputedStyle(this, ""); ret = c && c.getPropertyValue(prop) || ""; });
} else if (elem.currentStyle) {
var newProp = prop.replace(/-(w)/g,function(m,c){return c.toUpperCase();}); ret = elem.currentStyle[prop] || elem.currentStyle[newProp];