假设一个网页有一个字符串,如“我是一个简单的字符串”,我想找到。如何使用JQuery来实现这一点?
当前回答
如果你只是想要最接近你正在搜索的文本的节点,你可以使用这个:
$('*:contains("my text"):last');
即使你的HTML看起来像这样,这也可以工作:
<p> blah blah <strong>my <em>text</em></strong></p>
使用上面的选择器将找到<strong>标记,因为这是包含整个字符串的最后一个标记。
其他回答
这个函数应该可以工作。基本上做一个递归查找直到我们得到一个不同的叶节点列表。
function distinctNodes(search, element) {
var d, e, ef;
e = [];
ef = [];
if (element) {
d = $(":contains(\""+ search + "\"):not(script)", element);
}
else {
d = $(":contains(\""+ search + "\"):not(script)");
}
if (d.length == 1) {
e.push(d[0]);
}
else {
d.each(function () {
var i, r = distinctNodes(search, this);
if (r.length === 0) {
e.push(this);
}
else {
for (i = 0; i < r.length; ++i) {
e.push(r[i]);
}
}
});
}
$.each(e, function () {
for (var i = 0; i < ef.length; ++i) {
if (this === ef[i]) return;
}
ef.push(this);
});
return ef;
}
如果你只是想要最接近你正在搜索的文本的节点,你可以使用这个:
$('*:contains("my text"):last');
即使你的HTML看起来像这样,这也可以工作:
<p> blah blah <strong>my <em>text</em></strong></p>
使用上面的选择器将找到<strong>标记,因为这是包含整个字符串的最后一个标记。
只是添加到托尼米勒的答案,因为这让我达到了我所寻找的90%,但仍然没有工作。添加。length > 0;他的代码让我的脚本工作。
$(function() {
var foundin = $('*:contains("I am a simple string")').length > 0;
});
这将只选择包含“I am a simple string”的叶元素。
$('*:contains("I am a simple string")').each(function(){
if($(this).children().length < 1)
$(this).css("border","solid 2px red") });
将以下内容粘贴到地址栏以测试它。
javascript: $('*:contains("I am a simple string")').each(function(){ if($(this).children().length < 1) $(this).css("border","solid 2px red") }); return false;
如果你想抓取“I am a simple string”。首先将文本像这样包装在元素中。
$('*:contains("I am a simple string")').each(function(){
if($(this).children().length < 1)
$(this).html(
$(this).text().replace(
/"I am a simple string"/
,'<span containsStringImLookingFor="true">"I am a simple string"</span>'
)
)
});
然后这样做。
$('*[containsStringImLookingFor]').css("border","solid 2px red");
通常,jQuery选择器不会在DOM中的“文本节点”中进行搜索。但是,如果您使用.contents()函数,文本节点将被包括在内,那么您可以使用nodeType属性仅过滤文本节点,并使用nodeValue属性搜索文本字符串。
$('*', 'body') .andSelf() .contents() .filter(function(){ return this.nodeType === 3; }) .filter(function(){ // Only match when contains 'simple string' anywhere in the text return this.nodeValue.indexOf('simple string') != -1; }) .each(function(){ // Do something with this.nodeValue });
推荐文章
- 如何获得一个键/值JavaScript对象的键
- UILabel对齐文本到中心
- 什么时候JavaScript是同步的?
- 在jQuery中取消<select>的最佳方法?
- jQuery的“输入”事件
- 错误"Uncaught SyntaxError:意外的标记与JSON.parse"
- 给一个数字加上st, nd, rd和th(序数)后缀
- 在jQuery中的CSS类更改上触发事件
- jQuery日期/时间选择器
- 我如何预填充一个jQuery Datepicker文本框与今天的日期?
- jQuery添加必要的输入字段
- JavaScript错误(Uncaught SyntaxError:意外的输入结束)
- navigator。gelocation。getcurrentposition有时有效有时无效
- 我如何使用jQuery按字母顺序排序一个列表?
- 如何在jQuery检索复选框值