http://www.sowang.com/Internet/2001-06-27-08.htm

解决方案 »

  1.   

    用Javascript制作站内搜索器 
      
        用JavaScript做的站内搜索不仅编程实现、维护起来很简单,而且它能在客户端浏览器直接执行,无须服务器的支持,也可以省去申请有脚本执行权限空间的麻烦。所以,只要你愿意动手,有个人主页就能有自己的站内搜索。下面让我们共同来做一个基于JavaScript的站内搜索的脚本,可不要小看它,做完了你就知道它的好处了。 
     
       首先,你要编写一个搜索表单,将用户要搜索的数据提交给JavaScript函数。最简单的代码如下,因为是最简单的HTML代码,所以就不作解释了: 
    <form name="search" onsubmit="goSearch(this)"> 
    <input type="text" size="22" name="searchStr" value="多个关键字请以空格隔开" onmouseover="this.focus()" onfocus="this.select()"> 
    <select name="select" size="1"> 
    <option selected>或者(or)</option> 
    <option>并且(and)</option> 
    <option selected>不包含(no)</option> 
    </select> 
    <input type="submit" name="submit" value="搜索"> 
    </form> 
    其次,要对你的站点的数据初始化。这是搜索时要用到的数据库,站点更新只要更改这些数据就行了。对于这个数据库,建议单独存为一个文件,在这里我们先存为相同路径下的"db.js" 
    /* 站点数据库db.js开始 */ 
    function initArray(){ /* 定义数组初始化函数 */ 
    this.length=initArray.arguments.length; 
    for(var i=0;i<this.length;i++) this[i]=initArray.arguments[i]; 

    /* 定义待搜索的页面的标题,没有先后顺序,应将待搜索的页面都列出 */ 
    var titles=new initArray('页面标题1','页面标题2',……); 
    /* 这些页面的详细说明,位置应该与它们的标题一致 */ 
    var descriptions=new initArray('详细说明1','详细说明2',……); 
    /* 待搜索页面的地址,建议使用在你站点上的相对地址,位置也应与标题、说明相一致 */ 
    var URLs=new initArray('url1','url2',……); 
    /* 站点数据库db.js结束 */ 
    第三步,初始化用户输入的搜索字符串,并将它传递给搜索函数,列出结果。 
    function goSearch(){ 
    var searchStr=document.search.searchStr.value; /* 取得表单中的用户输入的搜索字符 */ 
    var string1=searchStr.toLowerCase(); /* 转换为小写,避免大小写敏感 */ 
    var length1=string1.length; 
    var string2=''; 
    for(var i=0;i<3;i++){ /* 取得搜索的字符串的各个关键字的逻辑关系 */ 
    if(document.search.select.options[i].selected) logic=i;} 
    if(length1!=0&&string1!=' '&&string1!=' '){ /* 滤掉"空"关键字 */ 
    for(i=0;i<length1;i++){ /* 将表单中的用户输入的搜索字符串的空格转换为"+"号 */if(string1.charAt(i)==' ') string2+='+'; 
    else string2+=string1.charAt(i);} 
    var search=string2.split('+'); /* 将转换过的搜索字符串以"+"为分割符分割为一个字符串数组 */ 
    uptodataSearch(search); 
    outWin=window.open('','',''); doc=outWin.document; 
    if(hitCount!=0){ /* 如果检索到符合要求的页面 */ 
    doc.write('<p>检索结果:共有'+hitCount+'个页面符合字符串:"<b><font color="ff0000">'+string2+'</font></b>":</p><ul>'); 
    for(i=0;i<hitCount;i++){ 
    doc.write('<li>'); 
    hrefmaker(titles[index[i]],URLs[index[i]],descriptions[index[i]]); /* 把检索到的数据一一列出,这里调用到的链接生成函数hrefmaker()在下面给出 */ 
    doc.write('</li>');} 
    doc.write('</ul>'); 

    else doc.write('<p>很抱歉,本站没有关于"<b><font color="ff0000">'+string2+'</font></b>"的内容!</p>'); 

    else alert('请输入要搜索的关键字!'); 

    第四,编写搜索函数。限于篇幅,给出的函数只有“不包含”的功能(就是输入的多个关键字必须全部满足要求才算符合搜索结果),要实现"或者"、"并且"功能请访问以下链接:http://ctsight.topcool.net/documents/pt_nr2000050902.html。 
    var hitCount=0; /* 全局变量hitCount,用于记录符合搜索要求的页数 */ 
    var index=new Array(); /* 全局变量数组,用于保存符合搜索要求的的页面在"数据库"db.js中的位置 */ 
    function uptodataSearch(searchStr){ /* 以经过处理的用户输入的搜索字符串为参数的搜索函数 */ 
    var tmpCount1=0,tmpCount2=0; 
    var tmpStr='',des=''; 
    var length1=searchStr.length,length2=titles.length; 
    for(var i=0;i<length2;i++){ /* 检索整个站点资料 */ 
    tmpStr=titles[i]+descriptions[i]; /* 将本次循环的站点数据的标题与详细内容合并,作为本次检索的范围*/ 
    des=tmpStr.toLowerCase(); /* 同样将它转化为小写 */ 
    tmpCount1=tmpCount2; 
    if(logic==2){ /* 如果逻辑关系是"不包括(not,!)" */ 
    if(des.indexOf(searchStr[0])!=-1){ //首先必须满足第一个关键字要求 
    for(j=1;j<length1;j++){ //检索其它关键字 
    if(des.indexOf(searchStr[j])==-1) tmpCount2++;} 
    if(tmpCount1==tmpCount2-length1+1){ /* 只有满足第一个关键字要求但不满足其它任何一个关键字的才算符合检索要求 */ 
    index[hitCount]=i; hitCount++;} } } } } 
    第五,编写搜索页面。 
    OK,基于JavaScript的站内搜索完工了。试一下,感觉如何?  
     
      

  2.   

    要用到服务器端脚本,比如php,jsp,asp之类的。通过脚本遍历web目录下的静态文件(比如所有htm和所有html后缀的文件),逐个文件读取他的内容然后看其中是否含有期望的关键字,有责记录下他的路径和文件名。
      

  3.   

    参考一下这个http://msdn.microsoft.com/workshop/samples/author/dhtml/refs/NavigateAndFind.htm
      

  4.   

    尽管JS是可以做到,但功能和效率还是有限的,如果是做搜索引擎第一首先还是Perl,它可以说是专门为做搜索引擎而设计的一种语言,它有着其它语言不可相比的字符处理能力!
      

  5.   

    很荣幸得到高手得指点!!
    孟子E章这个方法实在是高,但是好像只能搜titles(标题)和descriptions(描述)的内容,可我看到一个公司的资料光盘上所有网页内容的内容都可以搜,比如键入‘AB',它就找出所有网页内容有’AB'的页面。难道要把所有页面内容都加到descriptions数组中去?
      

  6.   

    另外估计这个光盘用的是另外的方法,因为点搜索他的ACTION=127.0.0.1.好像进入网站一样。查看源文件只能得到127.0.0.1[1]的形式,反正应该不是纯HTML文件。光盘上也找不到此文件。不知高手有什么看法?
      

  7.   

    TO: babystudio:
    我见到这个例子是在光盘上搜索的,也就是说它没有服务器环境。asp应该不能运行吧?另怎么遍历文件(夹)并把文件的内容全部读出来?望详细一点。
      

  8.   

    另:这个光盘是MAXIM公司的产品资料,有兴趣可以免费索取:
    http://www.maxim-ic.com.cn/tech/tech.htm
      

  9.   

    用第三方提供的检索系统可以不使用数据库,你可以去www.hylanda.com上看看