首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在jQuery中包装一组重复的元素?

如何在jQuery中包装一组重复的元素?
EN

Stack Overflow用户
提问于 2010-05-06 06:49:41
回答 2查看 840关注 0票数 1

在jQuery中,如何使用div包装一组可重复的元素?

例如,我有:

代码语言:javascript
运行
复制
img
h4
p  
img
h4
p
img
h4
p

我需要用div class="container"包装每个imgh4p集合。因此,它将看起来像:

代码语言:javascript
运行
复制
<div class="container"> img h4 p </div>
<div class="container"> img h4 p </div>
<div class="container"> img h4 p </div>

我一直收到嵌套的div.containers

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-05-06 07:04:21

你可以这样做:

代码语言:javascript
运行
复制
var elems = $("#content").find("img, h4, p");
for(var i = 0; i < elems.length; i+=3) {
  elems.slice(i, i+3).wrapAll("<div class='container'></div>");
}

这是通过选择这些元素所在的容器并获取这些特定类型来实现的,如果您想要的元素是所有类型,则可以用.children()替换.find(selector),在本例中,我对父元素使用了以下内容:

代码语言:javascript
运行
复制
<div id="container"></div>

You can see a working demo here

票数 1
EN

Stack Overflow用户

发布于 2010-05-06 07:09:29

您的示例非常简单,因此下面的示例将会起作用:

代码语言:javascript
运行
复制
$("h4").each(function () {
  $(this).prev().andSelf().next().andSelf().wrapAll("<div class='container'/>");
});

demo here

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2777301

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档