在从索引位置返回的字符串中查找空白

Find white space in a string back from an index position

本文关键字:字符串 查找 空白 返回 索引 位置      更新时间:2023-09-26

假设我有一个字符串,但文本可以是任何东西!

这是一个测试用例

"边界"是一个空格后的计数,这意味着charIndex=

(0)此(5) 是(8) a(10) 试验(15) 案例

上面的意思是从(0)到(5)这个词等于"this"。

如果我想知道刚刚使用的单词,我需要substrcharIndex开始,向后看,直到indexOf(' ')

示例:如果我想找到charIndex(10)中刚刚使用的单词,我将如何指示javascript向后看,直到下一个空格,并给我单词"a"。

是否可以使用Javascript或JQuery在处理时间尽可能短的情况下做到这一点?

更新

我决定实现我需要的东西,而不是照顾单词然后回去,我把单词分开,并用每个charIndex作为计数。代码如下:

var u = new SpeechSynthesisUtterance();
var words = element.innerHTML.split(' ');
var a = 0;
 u.text = element.innerHTML;
 u.lang = 'en-UK';
 u.rate = 0.7;
 u.onboundary = function(event) {
 console.log(words);
 element.innerHTML = element.innerHTML.replace(words[a], '<strong>' + words[a] + '</strong>');
  a++;       
  }

但由于这不是问题的答案,反向搜索字符串的最佳答案仍然是标记为正确的字符串,尽管根据字符串结构,它仍然需要一些工作。

不清楚确切的问题,但您可以在您的情况下使用lastindexof、indexof和substr的组合,也可以编写自己的内容。

注意:没有进行错误处理等。请这样做。

var stringToBeParsed="This is a test case"
i = stringToBeParsed.lastIndexOf(" ",8);
j = stringToBeParsed.indexOf(" ",i+1);
document.getElementById('output').innerText = stringToBeParsed.substr(i,j-i);

自定义

function parseBackward(stringToBeParsed, indexOfSpace){
    var output = '';
    for (var i = indexOfSpace-1; i >= 0; i--) {
        if(stringToBeParsed.charAt(i) == ' '){
            break;
        }
        output = stringToBeParsed.charAt(i) + output;
    }    
    document.getElementById('output').innerText = output;
}

如果我理解你的问题,你可以使用lastIndexOf:

var TC="This is a test case"
TC.lastIndexOf(" ",10)

这将返回9,使用lastIndexOf(string,position)向后搜索。

编辑:如果你需要这个词:

var TC="This is a test case"
TC.substr(TC.lastIndexOf(' ',10)+1,TC.length - TC.indexOf(' ',10));

所以你使用substr。首先从位置10的空格向后搜索(和1相加,得到字母的开头)以开始子串。作为第二个参数y,获取下一个出现项和长度的子项。

第2版:

好的,这个功能应该在不到毫秒的时间内工作:

function getWord(phrase,position){
  var last = phrase.indexOf(' ',position);
  var more=0
  if (last == -1){
    more = phrase.length;
  } else { more = phrase.indexOf(' ',position);}
  var word = phrase.substring(phrase.lastIndexOf(' ',position)+1,more);
  return(word);
}

在这个庞克http://plnkr.co/wfeitWvSvoLzqIknKFyg你可以查看一下如何在不到毫秒的时间内完成工作。如果你打开一个控制台,你会看到它是如何在指定的位置接受单词的。