jQuery: When creating a new element, do I need the ending tag?

前端 未结 4 1808
面向向阳花
面向向阳花 2021-01-02 01:54
var $div = $(\'
\').appendTo($(\'#header\'));

When creating new elements and adding them to the DOM, do you need the endi

相关标签:
4条回答
  • 2021-01-02 02:28

    You always need the ending tag to have proper html.

    But it is a fact that the majority of browsers let such mistakes slip. It's no reason to be lazy, though, you should not rely on the browsers' tolerance for your code to work. This tolerance is there to be able to display sites with a few mistakes, not to caution deliberately incorrect code.

    0 讨论(0)
  • 2021-01-02 02:37

    Although it may work if you don't use a closing tag (or at least self close the tag), you should add a closing tag (self-close) (as mentioned, for cross-platform compatibility):

    To ensure cross-platform compatibility, the snippet must be well-formed. Tags that can contain other elements should be paired with a closing tag:

    $('<a href="http://jquery.com"></a>');
    

    Alternatively, jQuery allows XML-like tag syntax (with or without a space before the slash):

    $('<a/>');
    

    Tags that cannot contain elements may be quick-closed or not:

    $('<img />');
    $('<input>');
    

    This is how jQuery creates the elements:

    If the HTML is more complex than a single tag without attributes, as it is in the above example, the actual creation of the elements is handled by the browser's innerHTML mechanism. In most cases, jQuery creates a new element and sets the innerHTML property of the element to the HTML snippet that was passed in. When the parameter has a single tag, such as $('<img />') or $('<a></a>'), jQuery creates the element using the native JavaScript createElement() function.


    Btw. you can also pass the data as second parameter:

    $('<div />', {'class': 'error', text: 'Error-Homie!'})
    
    0 讨论(0)
  • 2021-01-02 02:38

    you can probably do it like this

    $('<div/>',{class:'error'}).html('Error-Homie!').appendTo($('#header'));
    
    0 讨论(0)
  • 2021-01-02 02:44

    you need the ending tag : http://api.jquery.com/appendTo/ for example

    $('<p>Test</p>').appendTo('.inner');
    

    it should also be

    .appendTo('#header');
    

    and not

    .appendTo($('#header'));
    
    0 讨论(0)
提交回复
热议问题