当前位置: 首页 > 面试题库 >

jQuery .html()与.append()

张光辉
2023-03-14
问题内容

可以说我有一个空的div:

<div id='myDiv'></div>

这是:

$('#myDiv').html("<div id='mySecondDiv'></div>");

与:

var mySecondDiv=$("<div id='mySecondDiv'></div>");
$('#myDiv').append(mySecondDiv);

问题答案:

每当您将HTML字符串传递给jQuery的任何方法时,都会发生以下情况:

创建了一个临时元素,我们称它为x。x innerHTML设置为您传递的HTML字符串。然后,jQuery将把每个产生的节点(即x
childNodes)转移到新创建的文档片段中,然后将其缓存下一次。然后,它将片段的片段childNodes作为新的DOM集合返回

请注意,它实际上要比这复杂得多,因为jQuery进行了大量的跨浏览器检查和各种其他优化。例如,如果您仅将传递<div></div>jQuery(),则jQuery将采用快捷方式并简单地执行document.createElement('div')

innerHTML一般 的快的方法,虽然不要让支配你做什么,所有的时间。jQuery的方法并不element.innerHTML = ...像我所提到的那么简单-正如我提到的,正在发生大量检查和优化。

正确的技术在很大程度上取决于情况。如果要创建大量相同的元素,那么最后要做的就是创建一个巨大的循环,在每次迭代中创建一个新的jQuery对象。例如,使用jQuery创建100个div的最快方法:

jQuery(Array(101).join('<div></div>'));

还有一些可读性和维护性问题要考虑在内。

这个:

$('<div id="' + someID + '" class="foobar">' + content + '</div>');

......是 很多 难以维持比这个:

$('<div/>', {
    id: someID,
    className: 'foobar',
    html: content
});


 类似资料:
  • 在C语言中,假设每个算法被赋予完全相同的一组进程,那么先到先得、最短作业优先和循环之间的周转时间是否相等?还是调度算法不同?

  • 问题内容: 问题是,比较使用innerHTML的隐含条件并将文本节点附加到现有节点。幕后发生了什么? 到目前为止,我对此的想法是: 我猜都是在引起“ ReFlow”。 据我所知,后者(附加一个文本节点)也会导致DOM的完全重建(正确?他们都在这样做吗?)。 前者似乎还有其他讨厌的副作用,例如导致先前保存的对子节点的引用指向我正在修改innerHTML的节点,不再指向“当前DOM” /“子节点的正确

  • 问题内容: 为了为 HTML5 Doctype 定义字符集,我应该使用哪种表示法? 短: 长: 问题答案: 在HTML5中,它们是等效的。使用较短的一个,更容易记住和键入。浏览器支持很好,因为它是为向后兼容而设计的。

  • 连接的多个输入都相当于Yes的时候才会输出Yes。 用法 Your browser does not support the video tag. 案例:小闹钟 功能:今天15:10:00,响起猫叫声小闹钟 工作原理 当所有的输入都是Yes的时候,与节点才输出Yes。

  • 问题内容: 似乎有三种 相同的 方法可以独立于平台获取依赖于平台的“文件分隔符”: 我们如何决定何时使用哪个? 它们之间甚至有什么区别吗? 问题答案: 可以通过调用命令行参数或使用命令行参数覆盖 获取默认文件系统的分隔符。 获取默认文件系统。 获取文件系统的分隔符。请注意,作为一种实例方法,在需要代码在一个JVM中对多个文件系统进行操作的情况下,可以使用该方法将不同的文件系统传递给代码(而不是默认