亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

解析js原生方法創建表格效率測試

2019-11-20 22:33:22
字體:
來源:轉載
供稿:網友
我們先看一下三種算法以及在各種瀏覽器下的表現。
第一種: 直接操作dom。
復制代碼 代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>New Web Project</title>
    </head>
    <body>
<script>
microtime = function(get_as_float) {
            var now = new Date().getTime() / 1000;
            var s = parseInt(now, 10);
            return (get_as_float) ? now : (Math.round((now - s) * 1000) / 1000) + ' ' + s;
}
var m1 = microtime(true);
var table = document.createElement("table");
table.border = 1;
var tbody = document.createElement("tbody");
for(var i = 0; i < 1000; i++ ) {
    var tr = document.createElement("tr");
    for(var j = 0; j < 5; j++ ) {
        var td = document.createElement("td");
        td.appendChild(document.createTextNode("cell "+i+","+j));
        tr.appendChild(td);
    }
    tbody.appendChild(tr);
}
table.appendChild(tbody);
//chrome 0.028
//ie6 0.65
//ie7 0.40
//ie8 0.40
//ie9 0.35
//firefox14 0.035
//opera12 0.03
//safari5.17 0.014
document.body.appendChild(table);
var m2 = microtime(true);
alert(m2-m1);
</script>   
    </body>
</html>

第二種,借助借助createDocumentFragment。
復制代碼 代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>New Web Project</title>
    </head>
    <body>
<script>
microtime = function(get_as_float) {
            var now = new Date().getTime() / 1000;
            var s = parseInt(now, 10);
            return (get_as_float) ? now : (Math.round((now - s) * 1000) / 1000) + ' ' + s;
}
var m1 = microtime(true);
var table = document.createElement("table");
table.border = 1;
var tbody = document.createElement("tbody");
var fragment = document.createDocumentFragment();
for(var i = 0; i < 1000; i++ ) {
    var tr = document.createElement("tr");
    for(var j = 0; j < 5; j++ ) {
        var td = document.createElement("td");
        td.appendChild(document.createTextNode("cell "+i+","+j));
        tr.appendChild(td);
    }
    fragment.appendChild(tr);
}
tbody.appendChild(fragment);
table.appendChild(tbody);
//chrome 0.03
//ie6 0.68
//ie7 0.43
//ie8 0.43
//ie9 0.37
//firefox14 0.03
//opera12 0.04
//safari5.17 0.023
document.body.appendChild(table);
var m2 = microtime(true);
alert(m2-m1);
</script>   
    </body>
</html>

第三種:借助js的原生表格操作方法
復制代碼 代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>New Web Project</title>
</head>
<body>
<script>
microtime = function(get_as_float) {
var now = new Date().getTime() / 1000;
var s = parseInt(now, 10);
return (get_as_float) ? now : (Math.round((now - s) * 1000) / 1000) + ' ' + s;
}
var m1 = microtime(true);
var table = document.createElement("table");
table.border = 1;
var tbody = document.createElement("tbody");
table.appendChild(tbody);
for(var i = 0; i < 1000; i++ ) {
tbody.insertRow(i);
for(var j = 0; j < 5; j++ ) {
tbody.rows[i].insertCell(j);
tbody.rows[i].cells[j].appendChild(document.createTextNode("cell "+i+","+j));
}
var tr = document.createElement("tr");
tbody.appendChild(tr);
}
//chrome 0.19
//ie9 0.18
//ie8 0.25
//ie7 8.50
//ie6 20.45
//firefox14 0.065
//opera12 0.25
//safari5.17 0.18
document.body.appendChild(table);
var m2 = microtime(true);
alert(m2-m1);
</script>   
</body>
</html>

以上可以看出用原生的js創建表格效率最好,借助createDocumentFragment優勢不是很大(并不像網上說的那么明顯),借助insertRow和insertCell等在ie6、7下效率太低,不建議使用。

對第一種算法簡單的優化了一下:
復制代碼 代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>New Web Project</title>
    </head>
    <body>
<script>
microtime = function(get_as_float) {
            var now = new Date().getTime() / 1000;
            var s = parseInt(now, 10);
            return (get_as_float) ? now : (Math.round((now - s) * 1000) / 1000) + ' ' + s;
}
var m1 = microtime(true);
var table = document.createElement("table");
table.border = 1;
var tbody = document.createElement("tbody");
var i = 1000;
while(i--){
    var tr = document.createElement("tr"), j = 5;
    while(j--){
        var td = document.createElement("td");
        td.appendChild(document.createTextNode("cell "+i+","+j));
        tr.appendChild(td);
    }
    tbody.appendChild(tr);
}
table.appendChild(tbody);
//chrome 0.03
//ie6 0.66
//ie7 0.41
//ie8 0.41
//ie9 0.35
//firefox14 0.03
//opera12 0.03
//safari5.17 0.013
document.body.appendChild(table);
var m2 = microtime(true);
alert(m2-m1);
</script>   
    </body>
</html>

總結:對dom操作盡量使用createElement和appendChild,對于js內核提供的一些特殊方法慎用。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美在线视频免费观看| 九九视频这里只有精品| 国产精品成人在线| 欧美麻豆久久久久久中文| www.国产一区| www.亚洲成人| 色噜噜狠狠狠综合曰曰曰88av| 中文字幕日韩免费视频| 亚洲精品网站在线播放gif| 欧美精品亚州精品| 欧美日韩日本国产| 欧美精品video| 视频在线观看一区二区| 午夜精品福利电影| 中文字幕成人精品久久不卡| 韩曰欧美视频免费观看| 亚洲成人a级网| 亚洲精品美女久久久| 久久成人在线视频| 日本aⅴ大伊香蕉精品视频| 亚洲国产精品99| 欧美三级欧美成人高清www| 欧美孕妇与黑人孕交| 一区二区三区四区视频| 国产男人精品视频| 亚洲va欧美va在线观看| 久久精品视频一| 中文字幕日韩精品在线| 日韩精品视频免费在线观看| 亚洲欧美在线一区二区| 性视频1819p久久| 亚洲第一级黄色片| 最近2019好看的中文字幕免费| 日韩网站免费观看高清| 亚洲国产精品va在线看黑人动漫| 欧美高清理论片| 亚洲久久久久久久久久| 欧美精品久久久久久久久| 国产精品午夜一区二区欲梦| 日韩亚洲综合在线| 2019中文字幕在线免费观看| 疯狂欧美牲乱大交777| 成人免费网站在线看| 色综合久久中文字幕综合网小说| 成人在线播放av| 久久精品最新地址| 欧美性猛交xxxx久久久| 欧美视频中文字幕在线| 欧美黄色成人网| 91精品国产精品| 精品成人国产在线观看男人呻吟| 国产91色在线|免| 欧美日本国产在线| 91伊人影院在线播放| 亚洲欧美国产精品久久久久久久| 亚洲毛片在线观看| 91精品国产综合久久香蕉| 一本一本久久a久久精品牛牛影视| 日韩美女在线观看| 全亚洲最色的网站在线观看| 日韩免费av在线| 亚洲乱码国产乱码精品精| 国产成人亚洲综合91| 狠狠色狠狠色综合日日小说| 亚洲精品国产综合区久久久久久久| 一区二区三区精品99久久| 精品国产一区二区三区久久狼5月| 欧美在线视频免费播放| 日韩av在线导航| 91黑丝在线观看| 亚洲一区二区三区香蕉| 久久久久久久久久久久久久久久久久av| 亚洲欧美日韩中文在线| 国产精品美女免费看| 97色在线观看| 中文字幕日韩综合av| 国产精品入口福利| 国产精品久久久久久久久久久久| 5566成人精品视频免费| 日韩三级成人av网| 91麻豆国产语对白在线观看| 久久久久久久999精品视频| 欧美在线一区二区视频| 这里只有视频精品| 欧美特黄级在线| 97精品国产91久久久久久| 日韩精品在线观看一区二区| 久久久亚洲精选| 亚洲**2019国产| 亚洲国产精品电影| 亚洲欧美成人网| 久久久99免费视频| 国产成人精品视频在线| 中文字幕亚洲情99在线| 成人精品在线观看| 国产精品欧美亚洲777777| 午夜精品免费视频| 中文国产亚洲喷潮| 91在线免费看网站| 久久久久久久国产精品视频| 人九九综合九九宗合| 不卡av电影在线观看| 丝袜亚洲欧美日韩综合| 国产精品一区二区三区成人| 久久精品国产亚洲| 国产视频综合在线| 黄色91在线观看| 国产精品久久综合av爱欲tv| 国产999在线观看| 欧美激情视频网站| 国产亚洲精品成人av久久ww| 国产精品一区二区av影院萌芽| 中文字幕久热精品视频在线| 国产午夜精品理论片a级探花| 一区二区三区四区精品| 不卡av在线播放| 亚洲免费av片| 亚洲欧美综合v| 色妞在线综合亚洲欧美| 亚洲影院色无极综合| 日韩av影院在线观看| 91精品视频免费观看| 日韩免费观看高清| 91精品国产九九九久久久亚洲| 亚洲综合色av| 日韩美女免费观看| 久久免费成人精品视频| 欧美另类极品videosbestfree| 黑人巨大精品欧美一区二区一视频| 国产不卡av在线免费观看| 色999日韩欧美国产| 久久久久久国产精品三级玉女聊斋| 亚洲区免费影片| 亚洲精品720p| 久久精品国产亚洲精品2020| 欧美大片第1页| 久久免费精品日本久久中文字幕| 国产91成人在在线播放| 97超级碰在线看视频免费在线看| 日韩av手机在线观看| 亚洲欧美日韩视频一区| 久久中文字幕在线| 欧美日韩国产精品专区| 国产精欧美一区二区三区| 97国产真实伦对白精彩视频8| 亚洲色在线视频| 日韩欧美在线字幕| 在线免费看av不卡| 法国裸体一区二区| 久久偷看各类女兵18女厕嘘嘘| 欧美一级电影免费在线观看| 国产成人精品午夜| 在线视频欧美日韩精品| 国产亚洲欧美另类中文| 一区二区三区回区在观看免费视频| 亚洲欧美国产视频| 福利精品视频在线| 亚洲国产精品一区二区三区| 亚洲视频在线免费观看| 国产精品久久久久久久天堂| 欧美激情一级精品国产| 日韩在线中文字| 欧美激情视频三区| 亚洲人成电影网站色|