> 백엔드 개발 > PHP 튜토리얼 > javascript - 如何做这种模糊搜索

javascript - 如何做这种模糊搜索

WBOY
풀어 주다: 2016-06-06 20:49:12
원래의
1367명이 탐색했습니다.

<code class="lang-javascript">array = ["关于我们-网站公告-公告内页.html",
         "关于我们-网站公告-公告内页.html",
         "关于我们-网站公告-新闻内页.html",
         "关于我们.html",
         "联系我们.html",
         "我们的产品.html"]
</code>
로그인 후 복사
로그인 후 복사

输入关键字“关于公告”,在array中查找,显示下面的列表。 希望能提供一个思路~~

javascript - 如何做这种模糊搜索

回复内容:

<code class="lang-javascript">array = ["关于我们-网站公告-公告内页.html",
         "关于我们-网站公告-公告内页.html",
         "关于我们-网站公告-新闻内页.html",
         "关于我们.html",
         "联系我们.html",
         "我们的产品.html"]
</code>
로그인 후 복사
로그인 후 복사

输入关键字“关于公告”,在array中查找,显示下面的列表。 希望能提供一个思路~~

javascript - 如何做这种模糊搜索

将搜索关键字全部拆分,用.*拼接,然后正则匹配。javascript实现方法:

<code class="lang-javascript">var testarray = new Array('关于我们-网站公告-公告内页.html',
'关于我们-网站公告-新闻内页.html',
'关于我们.html',
'联系我们.html',
'我们的产品.html');
var searchstr = '关于公告';
var searcharr = searchstr.split('');
var reg = new RegExp(searcharr.join('.*'));
var resultarr=new Array();
for(var i=0;i<testarray.length if resultarr.push console.log></testarray.length></code>
로그인 후 복사

最后结果是:["关于我们-网站公告-公告内页.html", "关于我们-网站公告-新闻内页.html"]

不少js库可以实现你这个需求

http://www.open-open.com/ajax/AutoComplete.htm

把你的array, json_encode构造好传到页面中,交给js就行了.高级一点可以做成ajax的

如果不考虑英文、不考虑任意颠倒次序的话,那么思路如下:

r = new RegExp('关+于+公+告+');

然后 r.test(s)

至于如何把 '关于公告' 变成 '关+于+公+告+' ,可以:

sKeyword = '关于公告';

sKeyword = sKeyword.replace(/(.)/g, '$1+');

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿