代码如下
html:
<div>
<p>内容<span>我不获取的内容</span>内容</p>
</div>
js:
var content = $("div p").text();
var content = $("div p").html();
实现效果:以上两种方法text(),html()都要把span标签内的文本获取出来,而现在我想获取p标签下的“内容”,不包括p标签下的span标签下的内容,即 我需要让content = "内容内容"、而不是content = "内容<span>我不获取的内容</span>内容内容",也不是content = "内容我不获取的内容内容内容"
var obj = $($("div").html());
obj.find("span").remove();
alert(obj.html());
提供另一种思路:用正则替换
var content = $("div p").html();
var res=content.replace(/(.*)<[^>]*>.*<\/[^>]*>(.*)/,"$1$2");
var str = $('div p').contents().filter(function (index, content) {
return content.nodeType === 3;
}).text();
改了下第一个的答案,
var obj = $("div").clone().find(':nth-child(n)').remove();
alert(obj.html());
试试