17

HTMLコードをDOMに追加する方法は2つありますが、それを行うための最良の方法がわかりません。

最初の方法

最初の方法は簡単な方法です。HTMLコードを(jQueryを使用して)追加するだけで、次のようになります$('[code here]').appendTo(element);element.innerHTML = [code here];

2番目の方法

もう1つの方法は、次のようにすべての要素を1つずつ作成することです。

// New div-element
var div = $('<div/>', {
              id: 'someID',
              class: 'someClassname'
          });

// New p-element that appends to the previous div-element
$('<p/>', {
    class: 'anotherClassname',
    text: 'Some textnode',
}).appendTo(div);

document.createElementこのメソッドは、やのようなコア関数を使用しますelement.setAttribute

最初の方法と2番目の方法をいつ使用する必要がありますか?方法2は方法1よりも高速ですか?

編集-速度テストの結果

コードが続く3つの速度テストを実行しました。

$(document).ready(function(){
    // jQuery method - Above mentioned as the second method
    $('#test_one').click(function(){
        startTimer();
        var inhere = $('#inhere');
        for(i=0; i<1000; i++){
            $(inhere).append($('<p/>', {'class': 'anotherClassname' + i, text: 'number' + i}));
        }
        endTimer();
        return false;
    });

    // I thought this was much like the jQuery method, but it was not, as mentioned in the comments
    $('#test_two').click(function(){
        startTimer();
        var inhere = document.getElementById('inhere');
        for(i=0; i<1000; i++){
            var el = document.createElement('p')
            el.setAttribute('class', 'anotherClassname' + i);
            el.appendChild(document.createTextNode('number' + i));
            inhere.appendChild(el);
        }
        endTimer();
        return false;
    });

    // This is the innerHTML method
    $('#test_three').click(function(){
        startTimer();
        var inhere = document.getElementById('inhere'), el;
        for(i=0; i<1000; i++){
            el += '<p class="anotherClassname' + i + '">number' + i + '</p>';
        }                
        inhere.innerHTML = el;
        endTimer();
        return false;
    });
});

これは次の本当に驚くべき結果をもたらしました

               Test One   Test Two   Test Three  
+-------------+---------+----------+------------+
| Chrome    5 | ~125ms  |  ~10ms   |   ~15ms    |
| Firefox 3.6 | ~365ms  |  ~35ms   |   ~23ms    |
| IE        8 | ~828ms  |  ~125ms  |   ~15ms    |
+-------------+---------+----------+------------+

全体として、innerHTMLメソッドは最速のようであり、多くの場合、最も読みやすいメソッドです。

4

3 に答える 3

2

実際には、どちらのメソッドも を使用しませんinnerHTML。どちらの場合も、jQuery は HTML を DOM ノードに変換します。jquery-1.3.2.js から:

// If a single string is passed in and it's a single tag
// just do a createElement and skip the rest
if ( !fragment && elems.length === 1 && typeof elems[0] === "string" ) {
    var match = /^<(\w+)\s*\/?>$/.exec(elems[0]);
    if ( match )
        return [ context.createElement( match[1] ) ];
}

// ... some more code (shortened so nobody falls asleep) ...

// Convert html string into DOM nodes
if ( typeof elem === "string" ) {
    // Fix "XHTML"-style tags in all browsers
    elem = elem.replace(/(<(\w+)[^>]*?)\/>/g, function(all, front, tag){
        return tag.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i) ?
            all :
            front + "></" + tag + ">";
    });
    // etc...
}

一般的に言えば、innerHTML を使用すると、DOM を操作するよりも時間がかかります。これは、HTML パーサー (HTML を DOM に解析する) を呼び出すためです。

于 2010-02-23T16:02:29.153 に答える
2

人々が自分でこれをテストする目的で、古い記事を指摘します。DOM メソッドは、実際にはすべてのマシンで innerHTML を打ち負かしているので、それが私の好みです。ただし、記事時点では平均でinnerHTMLの方が速かった。現在、違いは巨大なデータセットでのみ劇的に見られます。

于 2010-02-23T15:53:33.837 に答える
0

コードの後半で再利用する場合はdiv、それをビルドしてvar、通常は$プレフィックスを付けて、jQueryオブジェクトであることがわかるように配置します。それが1回限りのことである場合、私はただ次のことを行います。

 $('body').append(the stuff)
于 2010-02-23T15:56:09.940 に答える