作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
正如标题所说,假设我有一些网站,其中一些 div 内有文本,有没有办法突出显示它的某些部分并知道它是哪次出现的?如果文本中出现了 4 次单词“something”,我突出显示了第 3 次,我如何使用 Javascript/JQuery 获取该信息?
最佳答案
http://jsfiddle.net/g09g35xa/6/
这是一个似乎有效的方法。突出显示您想要的字符串,当您单击按钮时,它会提醒 div 中突出显示的单词的索引。
标记:
<div id="theDiv">
<p>The quick brown quick fox jumps over the lazy dog</p>
</div>
<br />
<input id="findIndex" type="button" value="Find Index Of Highlighted String" />
还有 JS:
function getSelectedHTML() {
try {
if (window.ActiveXObject) {
var c = document.selection.createRange();
return c.htmlText;
}
return getSelection().getRangeAt(0).toString();
} catch (e) {
if (window.ActiveXObject) {
return document.selection.createRange();
} else {
return getSelection();
}
}
}
function surroundSelectedElement() {
var nNd = document.createElement("span");
nNd.setAttribute("id","actualSelectedElement");
var w = getSelection().getRangeAt(0);
w.surroundContents(nNd);
}
$(function() {
// save originalHtml to reset later
var originalHtml = $("#theDiv").html();
$("#findIndex").click( function() {
// get the selected string
var selectedText = getSelectedHTML();
if(selectedText === '')
return;
// surround the selected area with a span, id = actualSelectedElement
surroundSelectedElement();
// build Regex to find all occurrences of string that was selected
var re = new RegExp(selectedText, "g");
// replace instances of string with span tags, class = selectedText
$("#theDiv").html($("#theDiv").html().replace(re, "<span class='selectedText'>" + selectedText + "</span>"));
// the actual one selected is contained within a span with id=actualSelectedElement, so get all spans with class=selectedText and find the index of the one with the extra span actualSelectedElement
var index = $('span.selectedText').index($('span#actualSelectedElement span.selectedText'));
alert(index);
// reset the html back to original
$("#theDiv").html(originalHtml);
});
});
关于javascript - 我如何找到突出显示的字符串出现了多少次,以及它出现在哪一次?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27322148/
有没有一种方法可以“标记”对象的属性,使它们在反射中“突出”? 例如: class A { int aa, b; string s1, s2; public int AA
我是一名优秀的程序员,十分优秀!