我有以下HTML结构:
$('#subgroup a').nextUntil('h3').wrapAll('<div></div>');
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id="subgroup">
<h3>Group name #1</h3>
<a href="#">Link #1</a>
<a href="#">Link #2</a>
<h3>Group name #2</h3>
<a href="#">Link #3</a>
<a href="#">Link #4</a>
</div>
我有这种扁平结构,因为我想使用jQuery UI的手风琴效果。我想在a
元素之间包含所有h3
元素。
但这导致一些a
元素消失。我尝试了很多选择器,但没有一个能够工作。我这样做了吗?
答案 0 :(得分:7)
这样的方法应该有效,但我猜测有很多不同的方法可以做到这一点:
$('#subgroup h3').each(function() {
$(this).nextUntil('h3').wrapAll('<div></div>');
});
答案 1 :(得分:0)
这是一些好的(和脏的)jQuerying之后的样子,以整理HTML:
<div id="subgr-productlist">
<h3>Serie 1000</h3>
<a id="product-PROD79" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD79" name="product-PROD79">Model 1010</a>
<a id="product-PROD80" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD80" name="product-PROD80">Model 1020</a>
<a id="product-PROD81" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD81" name="product-PROD81">Model 1030</a>
<a id="product-PROD82" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD82" name="product-PROD82">Model 1040</a>
<a id="product-PROD83" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD83" name="product-PROD83">Model 1050</a>
<h3>Serie 2000</h3>
<a id="product-PROD234" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD234" name="product-PROD234">Model 2010</a>
<h3>Serie 3000</h3>
<a id="product-PROD85" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD85" name="product-PROD85">Model 3010</a>
<h3>Serie 4000</h3>
<a id="product-PROD86" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD86" name="product-PROD86">Model 4010</a>
<a id="product-PROD87" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD87" name="product-PROD87">Model 4020</a>
<a id="product-PROD88" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD88" name="product-PROD88">Model 4030</a>
<a id="product-PROD89" href="/global/hygiene/touchfree-dispensers/dispensers/products.aspx?ProductId=PROD89" name="product-PROD89">Model 4040</a>
</div>
换句话说,所有其他a
元素都会消失吗?
然后我运行这个jQuery脚本:
$('#subgr-productlist h3').each(function(){
$(this).nextUntil('h3').wrapAll('<div class="test"></div>');
});
但这导致#subgr-productlist div
呈现如下:
<div id="subgr-productlist">
<h3>Serie 1000</h3>
<h3>Serie 2000</h3>
<h3>Serie 3000</h3>
<div class="test">
<a id="product-PROD85" href="/global/hygiene/touchfree-dispensers/dispensers/products/products.aspx?ProductId=%20Model%203010" name="product-PROD85"></a>
</div>
<h3>Serie 4000</h3>
</div>