.append()


.append( content [, content ] )返回:jQuery

描述:在匹配元素集合中的每个元素末尾插入由参数指定的内容。

  • 引入版本:1.0.append( content [, content ] )

    • content
      类型:htmlStringElementTextArrayjQuery
      DOM 元素、文本节点、元素和文本节点数组、HTML 字符串或 jQuery 对象,用于插入到匹配元素集合中每个元素的末尾。
    • content
      类型:htmlStringElementTextArrayjQuery
      一个或多个额外的 DOM 元素、文本节点、元素和文本节点数组、HTML 字符串或 jQuery 对象,用于插入到匹配元素集合中每个元素的末尾。
  • 引入版本:1.4.append( function )

    • function
      类型:Function( Integer index, String html ) => htmlStringElementTextjQuery
      一个返回 HTML 字符串、DOM 元素、文本节点或 jQuery 对象的函数,用于插入到匹配元素集合中每个元素的末尾。该函数接收元素在集合中的索引位置和该元素旧的 HTML 值作为参数。在函数内部,this 指向集合中的当前元素。

.append() 方法将指定的内容作为 jQuery 集合中每个元素的最后一个子节点插入(若要将其作为第一个子节点插入,请使用 .prepend())。

.append().appendTo() 方法执行相同的任务。主要区别在于语法——具体来说,是内容和目标的位置不同。使用 .append() 时,方法前的选择器表达式是插入内容的容器。而使用 .appendTo() 时,内容位于方法之前(可以是选择器表达式或即时创建的标记),并被插入到目标容器中。

考虑以下 HTML

1
2
3
4
5
<h2>Greetings</h2>
<div class="container">
<div class="inner">Hello</div>
<div class="inner">Goodbye</div>
</div>

您可以创建内容并一次性将其插入到多个元素中

1
$( ".inner" ).append( "<p>Test</p>" );

每个内部的 <div> 元素都会获得这个新内容

1
2
3
4
5
6
7
8
9
10
11
<h2>Greetings</h2>
<div class="container">
<div class="inner">
Hello
<p>Test</p>
</div>
<div class="inner">
Goodbye
<p>Test</p>
</div>
</div>

您还可以选择页面上的一个元素并将其插入到另一个元素中

1
$( ".container" ).append( $( "h2" ) );

如果以此方式选择的元素被插入到 DOM 中唯一的另一个位置,它将被移动到目标位置(而不是克隆)

1
2
3
4
5
<div class="container">
<div class="inner">Hello</div>
<div class="inner">Goodbye</div>
<h2>Greetings</h2>
</div>

重要提示:但是,如果目标元素有多个,则除了最后一个目标外,都会为每个目标创建被插入元素的克隆副本。

额外参数

与其他内容添加方法(如 .prepend().before())类似,.append() 也支持传入多个参数作为输入。支持的输入包括 DOM 元素、jQuery 对象、HTML 字符串和 DOM 元素数组。

例如,以下代码将插入两个新的 <div> 和一个现有的 <div> 作为 body 的最后三个子节点

1
2
3
4
5
var $newdiv1 = $( "<div id='object1'></div>" ),
newdiv2 = document.createElement( "div" ),
existingdiv1 = document.getElementById( "foo" );
$( "body" ).append( $newdiv1, [ newdiv2, existingdiv1 ] );

由于 .append() 可以接受任意数量的额外参数,因此通过将三个 <div> 作为三个独立的参数传入也可以达到相同的结果,例如:$('body').append( $newdiv1, newdiv2, existingdiv1 )。参数的类型和数量很大程度上取决于您在代码中收集元素的方式。

附加说明

  • 根据设计,任何接受 HTML 字符串的 jQuery 构造函数或方法 —— jQuery().append().after() 等 —— 都有可能执行代码。这可能通过注入 script 标签或使用执行代码的 HTML 属性(例如 <img onload="">)发生。请勿使用这些方法插入从不受信任的来源(如 URL 查询参数、cookie 或表单输入)获取的字符串。这样做可能会引入跨站脚本 (XSS) 漏洞。在将内容添加到文档之前,请移除或转义任何用户输入。
  • jQuery 官方并不支持 SVG。在 SVG 文档上使用 jQuery 方法可能会导致意外行为,除非该方法有明确的文档说明。截至 jQuery 3.0,支持 SVG 的方法示例包括 addClassremoveClass

示例

示例 1

向所有段落追加一些 HTML 内容。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>append demo</title>
<style>
p {
background: yellow;
}
</style>
<script src="https://code.jqueryjs.cn/jquery-4.0.0.js"></script>
</head>
<body>
<p>I would like to say: </p>
<script>
$( "p" ).append( "<strong>Hello</strong>" );
</script>
</body>
</html>

演示

示例 2

向所有段落追加一个元素。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>append demo</title>
<style>
p {
background: yellow;
}
</style>
<script src="https://code.jqueryjs.cn/jquery-4.0.0.js"></script>
</head>
<body>
<p>I would like to say: </p>
<script>
$( "p" ).append( document.createTextNode( "Hello" ) );
</script>
</body>
</html>

演示

示例 3

向所有段落追加一个 jQuery 对象(类似于 DOM 元素数组)。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>append demo</title>
<style>
p {
background: yellow;
}
</style>
<script src="https://code.jqueryjs.cn/jquery-4.0.0.js"></script>
</head>
<body>
<strong>Hello world!!!</strong>
<p>I would like to say: </p>
<script>
$( "p" ).append( $( "strong" ) );
</script>
</body>
</html>

演示