- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个像这样的html
<ul>
<li>This is text</li>
</ul>
<p> bbbb ccc</p>
<p> <b> bbbb ccc</b></p>
我有所有单词索引,所以我想根据索引高亮每个文本,所以我是否可以将其转换为这种形式(将 id 分配给第一个父级):
<ul>
<li id="0">This is text</li>
</ul>
<p id="12"> bbbb ccc<p/>
<p> <b id="22"> bbbb ccc</b><p/>
id代表单词的第一个索引。
我正在尝试以下解决方案,该解决方案仅适用于仅文本包含在 p 标签中的情况,并且它在那里工作正常。但问题是当我们的 html 中有其他标签时。
$(document).ready(function() {
var allP = $("#inputText").find("p");
var indexCount = 0;
$.each(allP, function(key, value) {
var paraText = $(value).text().trim();
var textCount = paraText.length;
if (textCount > 0) {
$("#inputText p").eq(key).addClass('' + indexCount);
indexArray.push(indexCount);
}
indexCount += textCount;
});
});
function changeColor(index, word) {
var alreadyTxt = $('.highlightClass').text();
$('.highlightClass').replaceWith(alreadyTxt);
var paraVal = getIndexVal(index);
if (paraVal != -1) {
var txt = $('.' + paraVal).text();
var filteredText = txt.substr(0, index - paraVal) + '<span class="highlightClass">' + word + '</span>' + txt.substr(index - paraVal + word.length);
$('.' + paraVal).html(filteredText)
}
}
function getIndexVal(ind) {
var retunValue = -1;
var lastIndex = 0;
$.each(indexArray, function(key, value) {
if (ind <= value) {
retunValue = lastIndex;
return false;
}
lastIndex = value;
});
return retunValue;
}
如果还有其他更好的解决方案请推荐我,谢谢
最佳答案
$(document).ready(function(){
var id_array =[];
$('[id]').each(function() {
id_array.push(parseInt($(this).attr("id")));
console.log(parseInt($(this).attr("id")));
});
// Sort ID
id_array.sort(function(a, b){return a-b});
// highlight each ID by serialy
for (i = 0; i < id_array.length; i++) {
// highlight or change background of each id
$("#"+id_array[i]).css("background-color", "yellow");
// You can define delay option here to sea effect
}
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script>
<ul>
<li id="0">This is text</li>
</ul>
<p id="12"> bbbb ccc<p/>
<p> <b id="22"> bbbb ccc</b><p/>
<p> <b id="2"> 22222</b><p/>
关于javascript 如何逐字阅读并突出显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36306356/
我正在尝试返回数组“seats”,它本质上应该从文本文件返回数据 - 15x30 网格“#”。我已经尝试了很多东西,但我感到很沮丧,因为我对 java 的经验很少。我的代码可以编译,但在调用该方法时无
对于任何输入的字符串,我们需要按任意顺序的单词匹配来查找 super 字符串。即输入字符串中的所有单词必须以任何顺序出现在输出字符串中。例如给定数据集:“字符串搜索”“Java 字符串搜索”“手动 C
我有一个文本文件,其中包含一些我想放入二维数组中的内容。该文本文件由等长的句子组成。如何将每个单词放入数组? 文本文件的例子是- This is stackoverflow I am user 这个文
我正在编写一个实用程序,它接受一个 .resx 文件并创建一个包含 .resx 文件中所有名称/值对属性的 javascript 对象。这一切都很好,直到 .resx 中的值之一是 该经销商接受电子订
我输入了大量的数学表达式和方程式,我想为每个表达式和方程式打印出 latex 表示形式。到目前为止,我已经尝试过 Sage 和 sympy,但棘手的部分是不对表达式中的术语重新排序。 所以,如果我的输
我正在尝试通过实现异步任务在 android (java) 中流式传输 chatgpt api 的响应(逐字),但我收到错误。我正在将 java 的 HTTPurlconnection 库与输入和输出
我正在尝试通过实现异步任务在 android (java) 中流式传输 chatgpt api 的响应(逐字),但我收到错误。我正在将 java 的 HTTPurlconnection 库与输入和输出
我是一名优秀的程序员,十分优秀!