add() 将元素添加到匹配元素的集合中。这是jquery参考手册上的表述。但其提供的例子链接错误,因此没有对add()的实例说明。这里就提供几个例子,以便更好的掌握add()的用法。
例一
<!DOCTYPE html> <html> <head> <style> div { width:60px; height:60px; margin:10px; float:left; } p { clear:left; font-weight:bold; font-size:16px; color:blue; margin:0 10px; padding:2px; } </style> <script language="JavaScript" type="text/JavaScript" src="http://www.w3school.com.cn/jquery/jquery.js"></script> <script> $(document).ready(function(){ $("div").css("border", "2px solid red").add("p").css("background", "yellow"); }); </script> </head> <body> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <p>Added this… (notice no border)</p> </body> </html>结果如下图所示:
解说:这里的add("p")相当于和的意思,就是说$("div")的css和p的css。这里注意的是div是有边框的。而p没有。
例二
<body> <p>Hello</p><span>Hello Again</span> </body>
$("p").add("span").css("background", "yellow");结果如下图所示:
$("p,span").css("background","yellow");例三:
<body> <p>Hello</p> </body>
$("p").clone().add("<span>Again</span>").appendTo(document.body);结果如下:
clone()复制的意思;复制一个p和把<span>Again</span>插入到文档的body中。
这里插一句:如果不用clone(),则原来的p不存在了。看下面例子:
<script> $(document).ready(function(){ $("p").add("<span>Again</span>").appendTo(document.body); alert($("body").html()); }); </script> </head> <body> <p>Hello</p> </body> </html>结果如下图所示:
例四:
<body> <p>Hello</p><span id="a">Hello Again</span> </body>
$("p").add(document.getElementById("a")).css("background", "yellow");结果如下:
这表明add()中的参数不仅可以是选择器,也可以是DOM元素。