jquery如何获取标签本生的文本内容,不获取本身子级元素及子级元素的内容

代码如下
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 = "内容我不获取的内容内容内容"

阅读 12.5k
6 个回答

经测试通过的代码:

var obj = $("div").children("p").clone();
obj.find(':nth-child(n)').remove();
console.log(obj.html());

因为我也遇到同楼主一样的需求,于是搜到此处,结合 @里沃特@TinTinSH 二者的答案分析及实战得出上述结果,不破坏原文档并能实现效果;
当然该问题时间有点长,可能楼主等都已解决该问题,我此次回答并有日后他人解惑之目的!

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());
试试

新手上路,请多包涵

其实这里用原生js的childNodes会更好
console.log($('div p')[0].childNodes[0].data)
//输出 “内容”

推荐问题
宣传栏