1.innerHTML
這個大家一定都很熟悉,可讀可寫,修改元素內容相當快捷方便,在兼容問題上可以參考W3Help中一個知識記錄。
2.outerHTML
此方法可以用於對元素自身的快速替換,比如:
復制代碼 代碼如下:
<p id="hello">Hello, I am a demo</p>
$('hello').outerHTML = '<p>Hello, I am a replacement</p>';
遺憾的是,firefox目前還不支持(我當前用firefox8),其他浏覽器支持的還不錯,在ff中可以用innerHTML來模擬實現。
3.documentFragment
DocumentFragment能實現高效率的DOM節點插入操作,我們可以新建一個DocumentFragment。
var docFragment = document.createDocumentFragment();
它支持元素節點的appendChild方法,可以利用它進行追加節點,相當於內存中的一個臨時空間, 然後一次性加入DOM Tree中,較少浏覽器相關的reflow和repaint事件,在之前的博文中有提到。
4.insertAdjacentHTML
這個方法很有意思,是IE4最先引入的,目前也寫入了HTML5標准,目前所有浏覽器都支持,ff是8才剛開始支持的。 它能夠實現在元素的裡外,共4個地方靈活的添加內容,例如:
復制代碼 代碼如下:
<!-- beforebegin --><p id="test"><!-- afterbegin -->hello, I am a demo.<!-- beforeend--></p><!-- afterend-->
$('test').insertAdjacentHTML('beforebegin', /* your content here */);
這確實很cool不是麼,但遺憾的是,IE自己引入,確在IE6~8的版本中存在不少bug,比如我測試中遇到如果元素是div的話, 能夠在四個地方,都能順利插入內容,這是我們所預期的,但是我換成p元素的話,‘beforebegin'和‘afterend'就會報錯, 它變得只支持p外部的內容插入,不允許插入到p的內部,還有tr,td不支持此方法等各種bug。IE9測下來,表現預期。 關於這個方法jQuery之父,有篇博客有講,感興趣的可以稍微參考下http://ejohn.org/blog/dom-insertadjacenthtml/
5.textContent
這個是針對元素中的文本內容的操作,提取元素本身和其子元素中文本內容,這個用的頻率不是很高,但還是要知道下, 比如:
復制代碼 代碼如下:
<div id="test"><p>whatever, blah blah.</p>hello,I am a <em>Demo</em></div>
$('test').textContent //whatever, blah blah.hello, I am a Demo
把文本直接連接起來。IE9+和其他浏覽器都很好的支持此方法。
6.innerText
這個也是由IE最初引入的,除了firefox,目前其他浏覽器也都支持,但是結果有些微妙的不同。在opera中,結果和textContent一致,在chrome中,與包含該文本元素的樣式有關。在IE9中,與包含該文本元素的樣式有關。 事實上,innerText和textContent看似差不多,但還是有一些值得注意的不同之處。 具體MDN上有一定的說明:
1.textContent能夠獲取script,style元素中得文本。innerText不行
2.innerText結果跟樣式有關,不能獲取隱藏元素的文本內容,textContent則不受限制
3.innerText會觸發浏覽器內部的reflow事件,而textContent不會,這個對效率有點影響。
當然對於IE6~8,我們可以比較容易地通過遍歷節點來實現textContent的效果。如犀牛書中所給出的解決方法:
復制代碼 代碼如下:
function textContent(e) {
var child, type, s = []; // s holds the text of all children
for(child = e.firstChild; child != null; child = child.nextSibling) {
type = child.nodeType;
if(type === 3 || type === 4) { //Text and CDATASection nodes
s.push(child.nodeValue);
} else if(type === 1) {
s.push(textContent(child));
}
return s.join('');
}
}