jQuery环绕文本

时间:2012-11-23 11:03:24

标签: javascript jquery text

我有以下

<div><span class="myspan">hello</span> this text has no span </div>

在jQuery中,如何在{this 1 has span span“文本周围包裹div或跨度?

3 个答案:

答案 0 :(得分:8)

对于您当前的示例,这是我的一行解决方案:

$("div span").detach().prependTo($("div").contents().wrap("<span />").end());

DEMO: http://jsfiddle.net/awwTA/

答案 1 :(得分:0)

这不是最好的解决方案,但可以帮助你......

<div id="myDiv"><span class="myspan">hello</span> this text has no span </div>

var div = $('div#myDiv');
var span = $('span.myspan');
div.remove(span);
div.html($('<span></span>').text(div.text()));

我猜你知道我想做什么

答案 2 :(得分:0)

您可以在父div中搜索任何文本(nodeType:3)元素,然后将每个文本包装在另一个div中。见下面的例子:

&#13;
&#13;
$('#myDiv').contents().filter(function(){
   return this.nodeType === 3;
}).wrapAll("<div class='red' />");
&#13;
.red { color: red; }
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="myDiv"><span class="myspan">Hello</span> this text has no span </div>
&#13;
&#13;
&#13;