如何一次获取一个p元素的内容

时间:2016-04-15 07:46:11

标签: javascript jquery html html5

使用jQuery,我需要单独解析每个<p>标记的内容,然后用新文本替换文本。

目前的代码如下:

str = $('p').text();
str = str.replace('yadayada','yada');
$('p').text(str);

目前正在获取所有<p>标签的内容,将它们连接起来,然后将大量文本块替换为每个<p>,这些文本很接近,但不是我喜欢的做。

有没有办法一次一个地获取每个<p>块的内容并仅用它的内容替换它?我不知道他们应用了哪些ID或类,因此需要使用通用标记。

非常感谢任何帮助! :)

3 个答案:

答案 0 :(得分:3)

使用text(fn)

  

返回要设置的文本内容的函数。接收集合中元素的索引位置和旧文本值作为参数。

$('p').text(function(_ text){
    return text.replace('yadayada','yada');
});

答案 1 :(得分:1)

使用接受回调的text()版本作为第二个参数,并从回调中返回替换的内容

&#13;
&#13;
$('p').text(function(i, str) {
  return str.replace('yadayada', 'yada');
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<p>yadayada-1</p>
<p>yadayada-2</p>
<p>yadayada-3</p>
<p>4</p>
&#13;
&#13;
&#13;

答案 2 :(得分:0)

您可以在收集时使用.each方法:

$('p').each(function (pEl) {
    var text = pEl.textContent;
});