【发布时间】:2011-02-25 08:37:11
【问题描述】:
我在网站的某个地方有一个特定的文本,比如说“棒棒糖”,我想用“棉花糖”替换所有出现的这个字符串。问题是我不知道文本到底在哪里。我知道我可以这样做:
$(body).html($(body).html().replace('lollypops', 'marshmellows'));
这可能行得通,但我需要尽可能少地重写 HTML,所以我在想这样的事情:
- 搜索字符串
- 找到最近的父元素
- 只重写最近的父元素
- 即使在属性中替换它,但不是全部替换它,例如在
class中替换它,而不是在src中替换它
例如,我会有这样的结构
<body>
<div>
<div>
<p>
<h1>
<a>lollypops</a>
</h1>
</p>
<span>lollypops</span>
</div>
</div>
<p>
<span class="lollypops">Hello, World!</span>
<img src="/lollypops.jpg" alt="Cool image" />
</p>
<body>
在这个例子中,每次出现的“棒棒糖”都会被替换,只有 <img src="... 会保持不变,实际被操作的元素只有 <a> 和 <span>s。
有人知道怎么做吗?
【问题讨论】:
-
有一个很好的替换文本插件。 jquery-replacetext-plugin。该插件替换文本,保持所有标签和属性不变。您还可以在 spotlight-jquery-replacetext 找到此插件的不错教程
标签: javascript jquery jquery-selectors