createElement + createTextNode oneliner?

前端 未结 3 1602
星月不相逢
星月不相逢 2021-02-06 07:45

I\'m adding a few thousand rows to a table so i need the speed of native javascript for this one.

Currently I\'m using:

nThName = document.createElement(         


        
相关标签:
3条回答
  • 2021-02-06 08:12

    like David Thomas suggested.. a helper function is clearly the best option:

    nTr.appendChild(newElement("TH", workers[i].name));
    
    function newElement(TagName, TextContent, ClassName) {
        var nTag = document.createElement(TagName);
        nTag.className = ClassName;
        nTag.appendChild(document.createTextNode(TextContent));
        return nTag;
    }
    

    Changed it with advice by Florian Margaine. Result is super fast. MANY times faster then pure knockout or jquery.

    var tplTbody = document.createElement("TBODY");
    var tplTr = document.createElement("TR");
    var tplTd = document.createElement("TD"); // Every element used has it's 'template'
    
    var nTbody = tplTbody.cloneNode();
    for(var i in rows) {
        var nTr = newElement(tplTr.cloneNode(), null, "someclass");
        for(var i in cells) {
            nTr.appendChild(newElement(tplTd.cloneNode(), cell[i].content);
        }
        nTbody.appendChild(nTr);
    }
    document.getElementById("myTable").appendChild(nTbody);
    
    
    function newElement(Tag, TextContent, ClassName) {
        if (TextContent !== undefined && TextContent != null)
            Tag.appendChild(document.createTextNode(TextContent));
        if (ClassName !== undefined && ClassName != null) 
            Tag.className = ClassName;
        return Tag;
    }
    
    0 讨论(0)
  • 2021-02-06 08:14

    So, you're looking for performance? One-liners don't help with that. Using document fragments and cloning nodes does help, however. But it requires a bit more code.

    var table = document.getElementById('t');
    var tr = table.querySelector('tr');
    var th = document.createElement('th');
    var clone;
    
    var df = document.createDocumentFragment();
    
    for (var i = 0; i < 100; i++) {
        // Performance tip: clone a node so that you don't reuse createElement()
        clone = th.cloneNode();
        clone.appendChild(document.createTextNode('hello' + i));
    
        // Performance tip: append to the document fragment
        df.appendChild(clone);
    }
    
    // Performance tip: append only once in the real DOM
    tr.appendChild(df);
    

    See jsfiddle demo: http://jsfiddle.net/3KGwh/3/

    Document fragments are basically mini-DOM, with limited methods. They're great because they allow you to get great performance, and you can append a single element to the real DOM.

    0 讨论(0)
  • 2021-02-06 08:25

    This can be done, as an example:

    document.body.appendChild(
        document.createElement('div').appendChild(
            document.createTextNode('hello')
        ).parentNode
    );
    

    JS Fiddle representative demo.

    I think it's just your approach to chaining that was off; given your specific demo code:

    nTr.appendChild(
        document.createElement('th').appendChild(
            document.createTextNode(workers[i].name)
        ).parentNode
    );
    

    The white-space here isn't essential, it's simply to more-clearly show what goes where.

    0 讨论(0)
提交回复
热议问题