天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript 異步的innerHTML使用分析

當然,這個分時加載技術只是一個輔助技術,本身沒有添加節點的能力。如今,另一種更奇特的技術Asynchronous innerHTML又被開發出來了,不能不贊一下外國人在這方面研究是非常超前的。
復制代碼 代碼如下:
function asyncInnerHTML(HTML, callback) {
var temp = document.createElement('div'),
frag = document.createDocumentFragment();
temp.innerHTML = HTML;//要加入的內容先放到這里。
(function(){
if(temp.firstChild) {
frag.appendChild(temp.firstChild);//然后一點點挪到文檔碎片
setTimeout(arguments.callee, 0);//利用異步調用自身拼湊文檔碎片,直到div的節點被搬空
} else {
callback(frag);//這里才是真正執行插入節點的操作
}
})();
}

此技術的優點:
1. 利用閉包解決 IE6 的內存溢出問題
2. 利用setTimeout(fn,0) 這個hack將操作從隊列中拖出,防止瀏覽器假死
3. 利用Document Fragment減少對頁面的渲染次數
4. 回調的節點可以使用 DOM 標準的手法(appendChild)插入(如IE的table,tbody,tr,td等標簽的innerHTML是只讀的)
使用方法:
復制代碼 代碼如下:
var htmlStr = '<div><p>...</p><p>...</p><div><div>...</div>';
asyncInnerHTML(htmlStr, function(fragment){
// You can treat 'fragment' as a regular node.
document.body.appendChild(fragment);
});

不過,這個方法在table中添加節點時并不是個個瀏覽器都行得通,不得不說是一大敗筆。經測試IE8,IE6,FF3.5渲染出現差錯,chrome,safari4,opera10等能完好地把表格渲染出來。估計是IE8等在把節點轉移到文檔碎片時發生節點丟失現象。

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
在FF3.5的firebug顯示下,table新添加的節點,標簽都丟失了。
flagment
在IE8的開發人員工具中,我們發現table新添加節點出錯嚴重,見于IE一慣的表現,這是很正常的事!
flagment
相關演示可見無憂的貼子,發現這種方法不是最佳的插入動態內容的方法。

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]

JavaScript技術javascript 異步的innerHTML使用分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 免费一级毛片在线观看 | 调教美丽的白丝袜麻麻视频 | vr亚洲成年网址在线观看 | 精品伊人久久 | 精品一区二区免费视频蜜桃网 | 伊人久久亚洲精品一区 | 精品人妻一区二区三区视频53 | 国产日韩成人内射视频 | 中文无码熟妇人妻AV在线 | 日日撸影院在线 | 双手绑在床头调教乳尖 | 亚洲熟女片嫩草影院 | 久久久久久久久久毛片精品美女 | 国产永久免费高清在线观看 | 少妇厨房愉情理9伦片视频 少妇被躁爽到高潮无码久久 | 2020国产欧洲精品视频 | 老师好爽你下面水好多视频 | 美女张开腿让男生桶动态图 | 在线观看亚洲AV无码每日更新 | 视频一区国产在线二区 | 爽爽窝窝午夜精品一区二区 | 中文字幕日本在线mv视频精品 | 乱h好大噗嗤噗嗤烂了 | 美女扒开腿让男生桶爽免费APP | 久久亚洲人成国产精品 | 最新无码国产在线视频9299 | babesvideos性欧美 | 99久久e免费热视频百度 | 精品一区二区三区四区五区六区 | 亚洲中文字幕永久在线 | 你的欲梦裸身在线播放 | 被六个男人躁到一夜同性 | 中文在线日韩亚洲制服 | 亚洲日本欧美日韩高观看 | 好爽胸大好深好多水 | www.狠狠色| 精品久久中文字幕有码 | 欧式午夜理伦三级在线观看 | 亚洲精品电影天堂网 | 日韩精品一区二区亚洲AV观看 | 忘忧草研究院一二三 |