四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

javascript 異步的innerHTML使用分析

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

此技術(shù)的優(yōu)點:
1. 利用閉包解決 IE6 的內(nèi)存溢出問題
2. 利用setTimeout(fn,0) 這個hack將操作從隊列中拖出,防止瀏覽器假死
3. 利用Document Fragment減少對頁面的渲染次數(shù)
4. 回調(diào)的節(jié)點可以使用 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中添加節(jié)點時并不是個個瀏覽器都行得通,不得不說是一大敗筆。經(jīng)測試IE8,IE6,F(xiàn)F3.5渲染出現(xiàn)差錯,chrome,safari4,opera10等能完好地把表格渲染出來。估計是IE8等在把節(jié)點轉(zhuǎn)移到文檔碎片時發(fā)生節(jié)點丟失現(xiàn)象。

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

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

JavaScript技術(shù)javascript 異步的innerHTML使用分析,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 地缚花子君少年第二季| 欧美13| 蜘蛛网中的女孩| 黑衣人| 行则将至上一句| 浪荡女人米尔内1985| 暧昧电影| 黄婉伶| va视频在线| 女攻男受调教道具| 我的幸运猫 电视剧| 法证先锋2| 离歌吉他谱| 美女写真视频高清福利| 五谷丰登图片| 红灯区观看| 尸家重地演员表| when you are old| 女同恋性吃奶舌吻完整版| 热点新闻素材| 我的女老师| 卢宇静| 张国强个人简历| 角膜塑形镜的价格| 谢容儿| 免费完整队列训练教案| 被五六个女同学掏蛋| 张国新| 张倩仪演过什么电视剧| 工会基层组织选举工作条例| 娟子演的所有电视剧| 报团云南旅游价格| 104房间| 大学英语综合教程3| marcia| 聊斋艳谭之荷花三娘子| 二胡独奏北国之春| 影片 - theav| 凯登克罗斯| 爱之梦钢琴谱| 养小动物的作文|