JavaScript中的模糊搜索算法

我们需要编写一个JavaScript String函数,该函数接受一个搜索字符串,可以松散地检查它所使用的字符串中的搜索字符串。

该函数应请看以下条件:它应循环搜索查询字母,并检查它们是否在字符串中以相同顺序出现。

例如-

('a haystack with a needle').fuzzySearch('hay sucks'); // false
('a haystack with a needle').fuzzySearch('sack hand'); // true

示例

const fuzzySearch = function (query) {
   const str = this.toLowerCase();
   let i = 0, n = -1, l;
   query = query.toLowerCase();
   for (; l = query[i++] ;){
      if (!~(n = str.indexOf(l, n + 1))){
         return false;
      };
   };
   return true;
};
String.prototype.fuzzySearch = fuzzySearch;
console.log(('a haystack with a needle').fuzzySearch('hay sucks'));
console.log(('a haystack with a needle').fuzzySearch('sack hand'));

输出结果

这将产生以下输出-

false
true