日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

编写HTML提高编写代码的效率,优化innerHTML操作(提高代码执行效率)

發布時間:2023/12/10 HTML 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 编写HTML提高编写代码的效率,优化innerHTML操作(提高代码执行效率) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

例子:我們要實現的效果是當用戶點擊鼠標的時候,就在舊數據上追加若干新數據。

如果使用標準DOM的話,完整代碼如下:

test

data

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);

}

};

注:一旦結構比較復雜的話,標準DOM需要編寫冗長的代碼。

如果使用innerHTML的話,部分代碼如下:

document.onmousedown = function() {

var html = "";

for (var i = 0; i < 10; i++) {

html += "

" + Math.random() + "

";

}

document.getElementsByTagName('div')[0].innerHTML += html;

};

注:innerHTML沒有標準DOM中的appendChild,所以使用了『+=』的方式,效率低下。

我們可以結合使用innerHTML和標準DOM,這樣二者的優點就兼得了,部分代碼如下:

document.onmousedown = function() {

var html = "";

for (var i = 0; i < 10; i++) {

html += "

" + Math.random() + "

";

}

var temp = document.createElement("div");

temp.innerHTML = html;

while (temp.firstChild) {

document.getElementsByTagName('div')[0].appendChild(temp.firstChild);

}

};

注:創建一個元素,然后注入innerHTML,接著在元素上使用標準DOM操作。

還不算完,Asynchronous innerHTML給出了更強悍的解決方法,部分代碼如下:

document.onmousedown = function() {

var html = "";

for (var i = 0; i < 10; i++) {

html += "

" + Math.random() + "

";

}

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);

}

})();

};

注:使用setTimeout防止堵塞瀏覽器,使用DocumentFragment減少渲染次數。

另:代碼在拼接字符串時還可以更快,詳見:Fastest way to build an HTML string。

總結

以上是生活随笔為你收集整理的编写HTML提高编写代码的效率,优化innerHTML操作(提高代码执行效率)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。