/source/layout/style/nsCSSDataBlock.cpp#562對於important的處理是這樣的:
if (aIsImportant) {
if (!HasImportantBit(aPropID))
changed = PR_TRUE;
SetImportantBit(aPropID);
} else {
// ...
source/layout/style/nsCSSDataBlock.h#219這裡面有條評論算是對上面代碼的解釋:
/** * Transfer the state for aPropID (which may be a shorthand) * from aFromBlock to this block. The property being transferred * is !important if aIsImportant is true, and should replace an * existing !important property regardless of its own importance * if aOverrideImportant is true. * * ... */
從上面可以看出,Firefox對於!important規則的判斷很簡單:將包含!important的樣式直接覆蓋了正常生成的樣式規則,然後如果解 析到後面還有!important規則時,再和以前的important規則比較優先級。就是說,使用!important的CSS規則是置為了最高優先 級,然後最高優先級中去判斷應用那個樣式。
結論就是,使用!important對於性能並沒有什麼負面影響。但是從可維護性角度考慮還是少用這個規則。不過這個規則在IE6中有bug(IE6 IE7(Q) IE8(Q) 不完全支持 !important 規則),使用的時候還要注意。