Javascript正则表达式抓取p标签的内容

时间:2012-12-09 19:20:44

标签: javascript regex

有人可以帮我一个正则表达式的代码,它会抓住这个p:

的内容

<p class="bc_shirt_name">101</p>

由于

4 个答案:

答案 0 :(得分:2)

当您的标记格式正确时,最好使用DOMParser

var parser = new DOMParser();
var doc = parser.parseFromString('<p class="bc_shirt_name">101</p>', "application/xml");
var contents = doc.documentElement.textContent;

这几乎适用于任何XML,而不仅仅是XHTML。我也可以在<tag>foo</tag>上使用它。

以下是演示:http://jsfiddle.net/vEeXX/

答案 1 :(得分:2)

您的浏览器应该能够解析HTML,不是吗?

var div = document.createElement("div");
div.innerHTML = '<p class="bc_shirt_name">101</p>';
var p = div.getElementsByTagName("p")[0];
var html = p.innerHTML; // content as html
var text = p.textContent || p.innerText; // content as plain text

答案 2 :(得分:0)

有很多方法,但这里有一种使用正则表达式的方法,原始问题:

var html = "<stuff><p class=\"bc_shirt_name\">101</p></stuff>";

var matches = html.match(/<p\s+class="bc_shirt_name">[\S\s]*?<\/p>/gi);
    matches = matches[0].replace(/(<\/?[^>]+>)/gi, ''); // Strip HTML tags?

alert(matches);​

JSFiddle演示: http://jsfiddle.net/tGTb7/

答案 3 :(得分:0)

var str = "<p class="bc_shirt_name">101</p>";
var match, result = "", 
regex = /<p\s+class="bc_shirt_name">(.*?)<\/p>/ig;

while (match = regex.exec(str)) {
  result += match[1]; 
  }
 alert(result);

结果变量将包含所需的数据。希望这有帮助。