欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

優(yōu)化innerHTML操作(提高代碼執(zhí)行效率)

 更新時間:2011年08月20日 22:55:44   作者:  
多數(shù)現(xiàn)代瀏覽器都實現(xiàn)了innerHTML操作,它的方便性讓我們愛不釋手,但如果使用不當(dāng),很容易出現(xiàn)效率問題,本文通過一個例子來說明如何優(yōu)化innerHTML操作。
例子:我們要實現(xiàn)的效果是當(dāng)用戶點擊鼠標(biāo)的時候,就在舊數(shù)據(jù)上追加若干新數(shù)據(jù)。
  如果使用標(biāo)準DOM的話,完整代碼如下:
復(fù)制代碼 代碼如下:

<html>
<head>
<title>test</title>
</head>
<body>
<div>
<p>data<p>
</div>
<script>
document.onmousedown = function() {
for (var i = 0; i < 10; i++) {
var p = document.createElement("p");
p.appendChild(document.createTextNode(Math.random()));
document.getElementsByTagName('div')[0].appendChild(p);
}
};
</script>
</body>
</html>

注:一旦結(jié)構(gòu)比較復(fù)雜的話,標(biāo)準DOM需要編寫冗長的代碼。
  如果使用innerHTML的話,部分代碼如下:
復(fù)制代碼 代碼如下:

<script>
document.onmousedown = function() {
var html = "";
for (var i = 0; i < 10; i++) {
html += "<p>" + Math.random() + "<p>";
}
document.getElementsByTagName('div')[0].innerHTML += html;
};
</script>

注:innerHTML沒有標(biāo)準DOM中的appendChild,所以使用了『+=』的方式,效率低下。
  我們可以結(jié)合使用innerHTML和標(biāo)準DOM,這樣二者的優(yōu)點就兼得了,部分代碼如下:
復(fù)制代碼 代碼如下:

<script>
document.onmousedown = function() {
var html = "";
for (var i = 0; i < 10; i++) {
html += "<p>" + Math.random() + "<p>";
}
var temp = document.createElement("div");
temp.innerHTML = html;
while (temp.firstChild) {
document.getElementsByTagName('div')[0].appendChild(temp.firstChild);
}
};
</script>

注:創(chuàng)建一個元素,然后注入innerHTML,接著在元素上使用標(biāo)準DOM操作。
  還不算完,Asynchronous innerHTML給出了更強悍的解決方法,部分代碼如下:
復(fù)制代碼 代碼如下:

<script>
document.onmousedown = function() {
var html = "";
for (var i = 0; i < 10; i++) {
html += "<p>" + Math.random() + "<p>";
}
var temp = document.createElement('div');
temp.innerHTML = html;
var frag = document.createDocumentFragment();
(function() {
if (temp.firstChild) {
frag.appendChild(temp.firstChild);
setTimeout(arguments.callee, 0);
} else {
document.getElementsByTagName('div')[0].appendChild(frag);
}
})();
};
</script>

注:使用setTimeout防止堵塞瀏覽器,使用DocumentFragment減少渲染次數(shù)。
  另:代碼在拼接字符串時還可以更快,詳見:Fastest way to build an HTML string。

相關(guān)文章

  • JavaScript?編寫枚舉的最有效方法分享

    JavaScript?編寫枚舉的最有效方法分享

    這篇文章主要介紹了JavaScript?編寫枚舉的最有效方法分享,JavaScript語言本身不支持枚舉。如果我們想模擬枚舉,我們可以使用一個對象。更多相關(guān)內(nèi)容感興趣的小伙伴可以參考一下
    2022-06-06
  • JavaScript表格隔行變色和Tab標(biāo)簽頁特效示例【附j(luò)Query版】

    JavaScript表格隔行變色和Tab標(biāo)簽頁特效示例【附j(luò)Query版】

    這篇文章主要介紹了JavaScript表格隔行變色和Tab標(biāo)簽頁特效,結(jié)合實例形式分析了javascript元素遍歷、事件響應(yīng)相關(guān)操作技巧,并附帶jQuery對應(yīng)實現(xiàn)代碼供大家參考,需要的朋友可以參考下
    2019-07-07
  • uniapp實現(xiàn)全局設(shè)置字體大小(小中大的字體切換)

    uniapp實現(xiàn)全局設(shè)置字體大小(小中大的字體切換)

    隨著UniApp的流行,越來越多的開發(fā)者選擇使用它來構(gòu)建跨平臺應(yīng)用程序,下面這篇文章主要給大家介紹了關(guān)于uniapp實現(xiàn)全局設(shè)置字體大小(小中大的字體切換)的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • 深入淺出JavaScript中base64編碼原理

    深入淺出JavaScript中base64編碼原理

    今天翻開舊項目發(fā)現(xiàn)挺多圖片相關(guān)的插件都是用?base64?來顯示圖片的。談到?base64,腦海遐想翩翩,思緒回蕩之下?base64?瑕瑜互見。這篇文章主要是記錄了工作中遇見的問題并加以總結(jié),如有不妥請指正
    2023-02-02
  • JavaScript實現(xiàn)簡單輪播圖效果

    JavaScript實現(xiàn)簡單輪播圖效果

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)圖片輪播,左右翻轉(zhuǎn),圖片切換顯示等效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • Bootstrap 模態(tài)對話框只加載一次 remote 數(shù)據(jù)的完美解決辦法

    Bootstrap 模態(tài)對話框只加載一次 remote 數(shù)據(jù)的完美解決辦法

    前端框架 Bootstrap 的模態(tài)對話框,可以使用 remote 選項指定一個 URL,這樣對話框在第一次彈出的時候就會自動從這個地址加載數(shù)據(jù)到 .modal-body 中,但是它只會加載一次,不過通過在事件中調(diào)用 removeData() 方法可以解決這個問題,具體操作方法,大家通過本文了解下吧
    2017-07-07
  • javascript 節(jié)點遍歷函數(shù)

    javascript 節(jié)點遍歷函數(shù)

    火狐官網(wǎng)上找到的一組函數(shù),相當(dāng)于treeWalker,有了它可以方便地在IE實現(xiàn)Traversal API 2的所有功能
    2010-03-03
  • JavaScript幾種形式的樹結(jié)構(gòu)菜單

    JavaScript幾種形式的樹結(jié)構(gòu)菜單

    今天我主要講3種不同展示的JavaScript樹結(jié)構(gòu)菜單,分別是懸浮層樹(Tree)、右鍵菜單樹(ContextMenu)和節(jié)點樹(TreeMenu),目前都支持無限級層次。
    2010-05-05
  • JavaScript實現(xiàn)三階幻方算法謎題解答

    JavaScript實現(xiàn)三階幻方算法謎題解答

    這篇文章主要介紹了JavaScript實現(xiàn)三階幻方算法謎題解答,三階幻方是指試將1~9這9個不同整數(shù)填入一個3×3的表格,使得每行、每列以及每條對角線上的數(shù)字之和相同,需要的朋友可以參考下
    2014-12-12
  • js利用正則表達式檢驗輸入內(nèi)容是否為網(wǎng)址

    js利用正則表達式檢驗輸入內(nèi)容是否為網(wǎng)址

    這篇文章主要為大家詳細介紹了js利用正則表達式檢驗輸入內(nèi)容是否為網(wǎng)址的相關(guān)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-07-07

最新評論