JavaScript 中的模糊搜索算法


我们需要编写一个 JavaScript 字符串函数,此函数可接收一个搜索字符串,并利用它松散地检查字符串。

该函数应在考虑以下准则的情况下:遍历搜索查询字母,然后检查它们是否按同顺序出现在字符串中。

例如 −

('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

更新于:25-11-2020

1K 多次访问

职业生涯扬帆起航

完成课程,获得认证

立即开始
广告