3

我在这里找不到这个,希望有人能提供帮助。

我需要将链接 (.more) 附加到它之前的段落 - 我确信这很简单,但不能完全正确:

<p>Lorem ipsum</p>

<p>Lorem ipsum</p>

<p>Lorem ipsum</p>

<a href="#" class="more">Read more</a>

<p>Lorem ipsum</p>

最终的 HTML 中可能会有更多的段落,我需要这样做的原因是 CMS 相关的。但基于上述,我的目标是:

<p>Lorem ipsum</p>

<p>Lorem ipsum</p>

<p>Lorem ipsum <a href="#" class="more">Read more</a></p>

<p>Lorem ipsum</p>

我试过了:

$(".more").appendTo("p");

但显然这会将它附加到所有段落......也许这是 prevAll 的工作,但我不能完全确定它。

非常感谢您的帮助!

4

2 回答 2

6

HTML

<p>Lorem ipsum</p>
<p>Lorem ipsum</p>
<p>Lorem ipsum</p>
<a href="#" class="more">Read more1</a>
<p>Lorem ipsum</p>
<a href="#" class="more">Read more2</a>

JS

$('p').each(function(e){
    if($(this).next('a').hasClass('more'))
       $(this).html($(this).html()+" ").append($(this).next('a')); 
});​

Example1Example2 带有多个 a 标签。

于 2012-04-21T16:53:52.293 回答
2

尝试使用

var more = $(".more");
more.prev().append(" ").append(more);
于 2012-04-21T16:49:38.147 回答