`
java_beginner_liyun
  • 浏览: 74518 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

带拼音的简单搜索引擎的实现

阅读更多

一、页面(HTML)

 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>demo.html</title>
	
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="this is my page">
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    
    <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->
    
	<script type="text/javascript" src="quickQuery-packer.js"></script>
	<link rel="stylesheet" type="text/css" href="quickQuery.css">
	
	<script type="text/javascript">

var arriveCityArray = new Array("","","");
	arriveCityArray[0] = new Array("0", "丽江", "LIJIANG");
	arriveCityArray[1] = new Array("1", "青岛", "QINGDAO");
	arriveCityArray[2] = new Array("2", "临沧", "LINCANG");
	arriveCityArray[3] = new Array("3", "林西", "LINXI");
	arriveCityArray[4] = new Array("4", "临沂", "LINYI");
	arriveCityArray[5] = new Array("5", "柳州", "LIUZHOU");
	arriveCityArray[6] = new Array("6", "洛阳", "LUOYANG");
	arriveCityArray[7] = new Array("7", "庐山", "LUSHAN");
	arriveCityArray[8] = new Array("8", "泸州", "LUZHOU");
	arriveCityArray[9] = new Array("9", "德宏芒市", "DEHONGMANGSHI");
	arriveCityArray[10] = new Array("10", "满洲里", "MANZHOULI");
	arriveCityArray[11] = new Array("11", "秦皇岛", "QINHUANGDAO");
	arriveCityArray[12] = new Array("12", "齐齐哈尔", "QIQIHAER");
	arriveCityArray[13] = new Array("13", "衢州", "QVZHOU");
	arriveCityArray[14] = new Array("14", "三亚", "SANYA");
	arriveCityArray[15] = new Array("15", "上海", "SHANGHAI");
	arriveCityArray[16] = new Array("16", "鄯善", "SHANSHAN");
	arriveCityArray[17] = new Array("17", "汕头", "SHANTOU");
	arriveCityArray[18] = new Array("18", "韶关", "SHAOGUAN");
	arriveCityArray[19] = new Array("19", "沙市", "SHASHI");
	arriveCityArray[20] = new Array("20", "沈阳", "SHENYANG");
	arriveCityArray[21] = new Array("21", "深圳", "SHENZHEN");
	arriveCityArray[22] = new Array("22", "石家庄", "SHIJIAZHUANG");
	arriveCityArray[23] = new Array("23", "思茅", "SIMAO");
	arriveCityArray[24] = new Array("24", "苏州", "SUZHOU");
	arriveCityArray[25] = new Array("25", "塔城", "TACHENG");
	arriveCityArray[26] = new Array("26", "太原", "TAIYUAN");
	arriveCityArray[27] = new Array("27", "天津", "TIANJIN");
	arriveCityArray[28] = new Array("28", "通化", "TONGHUA");
	arriveCityArray[29] = new Array("29", "通辽", "TONGLIAO");
	arriveCityArray[30] = new Array("30", "铜仁", "TONGREN");
	arriveCityArray[31] = new Array("31", "乌兰浩特", "WULANHAOTE");
	arriveCityArray[32] = new Array("32", "乌鲁木齐", "WULUMUQI");
	arriveCityArray[33] = new Array("33", "万州", "WANZHOU");
	arriveCityArray[34] = new Array("34", "潍坊", "WEIFANG");
	arriveCityArray[35] = new Array("35", "威海", "WEIHAI");
	arriveCityArray[36] = new Array("36", "温州", "WENZHOU");
	arriveCityArray[37] = new Array("37", "武汉", "WUHAN");
	arriveCityArray[38] = new Array("38", "芜湖", "WUHU");
	arriveCityArray[39] = new Array("39", "无锡", "WUXI");
	arriveCityArray[40] = new Array("40", "武夷山", "WUYISHAN");
	arriveCityArray[41] = new Array("41", "梧州", "WUZHOU");
	arriveCityArray[42] = new Array("42", "厦门", "XIAMEN");
	arriveCityArray[43] = new Array("43", "西安", "XIAN");
	arriveCityArray[44] = new Array("44", "襄樊", "XIANGFAN");
	arriveCityArray[45] = new Array("45", "西昌", "XICHANG");
	arriveCityArray[46] = new Array("46", "锡林浩特", "XILINHAOTE");
	arriveCityArray[47] = new Array("47", "兴城", "XINGCHENG");
	arriveCityArray[48] = new Array("48", "兴宁", "XINGNING");
	arriveCityArray[49] = new Array("49", "邢台", "XINGTAI");
	arriveCityArray[50] = new Array("50", "西宁", "XINING");
	arriveCityArray[51] = new Array("51", "西双版纳", "XISHUANGBANNA");
	arriveCityArray[52] = new Array("52", "徐州", "XVZHOU");
	arriveCityArray[53] = new Array("53", "延安", "YANAN");
	arriveCityArray[54] = new Array("54", "盐城", "YANCHENG");
	arriveCityArray[55] = new Array("55", "延吉", "YANJI");
	arriveCityArray[56] = new Array("56", "烟台", "YANTAI");
	arriveCityArray[57] = new Array("57", "宜宾", "YIBIN");
	arriveCityArray[58] = new Array("58", "宜昌", "YICHANG");
	arriveCityArray[59] = new Array("59", "银川", "YINCHUAN");
	arriveCityArray[60] = new Array("60", "义乌", "YIWU");
	arriveCityArray[61] = new Array("61", "永州", "YONGZHOU");
	arriveCityArray[62] = new Array("62", "元谋", "YUANMOU");
	arriveCityArray[63] = new Array("63", "榆林", "YULIN");
	arriveCityArray[64] = new Array("64", "张家界", "ZHANGJIAJIE");
	arriveCityArray[65] = new Array("65", "湛江", "ZHANJIANG");
	arriveCityArray[66] = new Array("66", "昭通", "ZHAOTONG");
	arriveCityArray[67] = new Array("67", "郑州", "ZHENGZHOU");
	arriveCityArray[68] = new Array("68", "舟山", "ZHOUSHAN");
	arriveCityArray[69] = new Array("69", "遵义", "ZUNYI");
	arriveCityArray[70] = new Array("70", "北京南苑", "BEIJINGNANYUAN");
	arriveCityArray[71] = new Array("71", "铱兰", "YILAN");
	arriveCityArray[72] = new Array("72", "梨山", "LISHAN");
	arriveCityArray[73] = new Array("73", "广元", "GUANGYUAN");
	arriveCityArray[74] = new Array("74", "大足", "DAZU");
	arriveCityArray[75] = new Array("75", "东胜", "DONGSHENG");
	arriveCityArray[76] = new Array("76", "庆阳", "QINGYANG");
	arriveCityArray[77] = new Array("77", "伊宁", "YINING");
	arriveCityArray[78] = new Array("78", "运城", "YUNCHENG");
	arriveCityArray[79] = new Array("79", "曼彻斯特", "MANCHESITE");
	arriveCityArray[80] = new Array("80", "巴厘岛", "BALIDAO");
	arriveCityArray[81] = new Array("81", "北干巴鲁", "BEIGANBALU");
	arriveCityArray[82] = new Array("82", "吉达", "JIDA");
	arriveCityArray[83] = new Array("83", "班贾尔马", "BANJAERMA");
	arriveCityArray[84] = new Array("84", "巴淡岛", "BADANDAO");
	arriveCityArray[85] = new Array("85", "巴东", "BADONG");
	arriveCityArray[86] = new Array("86", "巴厘巴板", "BALIBABAN");
	arriveCityArray[87] = new Array("87", "班达亚齐", "BANDAYAQI");
	arriveCityArray[88] = new Array("88", "棉丹", "MIANDAN");
	arriveCityArray[89] = new Array("89", "乌戎潘当", "WURONGPANDANG");
	arriveCityArray[90] = new Array("90", "比亚克", "BIYAKE");
	arriveCityArray[91] = new Array("91", "查亚普拉", "CHAYAPULA");
	arriveCityArray[92] = new Array("92", "万鸦老", "WANYALAO");
	arriveCityArray[93] = new Array("93", "特姆巴加普拉", "TEMUBAJIAPULA");
	arriveCityArray[94] = new Array("94", "日惹", "RIRE");
	arriveCityArray[95] = new Array("95", "三宝垄", "SANBAOLONG");
	arriveCityArray[96] = new Array("96", "苏拉", "SULA");
	arriveCityArray[97] = new Array("97", "巨港", "JVGANG");
	arriveCityArray[98] = new Array("98", "柏林", "BOLIN");
	arriveCityArray[99] = new Array("99", "不莱梅", "BULAIMEI");
	arriveCityArray[100] = new Array("100", "科隆", "KELONG");
	arriveCityArray[101] = new Array("101", "德雷斯顿", "DELEISIDUN");
	arriveCityArray[102] = new Array("102", "多特蒙德", "DUTEMENGDE");
	arriveCityArray[103] = new Array("103", "杜塞尔多夫", "DUSAIERDUOFU");
	arriveCityArray[104] = new Array("104", "埃尔福特", "AIERFUTE");
	arriveCityArray[105] = new Array("105", "腓特烈港", "FEITELIEGANG");
	arriveCityArray[106] = new Array("106", "明斯特", "MINGSITE");
	arriveCityArray[107] = new Array("107", "法兰克福", "FALANKEFU");
	arriveCityArray[108] = new Array("108", "汉诺威", "HANNUOWEI");
	arriveCityArray[109] = new Array("109", "汉堡", "HANBAO");
	arriveCityArray[110] = new Array("110", "霍夫", "HUOFU");
	arriveCityArray[111] = new Array("111", "基尔", "JIER");
	arriveCityArray[112] = new Array("112", "哈勒", "HALE");
	arriveCityArray[113] = new Array("113", "慕尼黑", "MUNIHEI");
	arriveCityArray[114] = new Array("114", "纽伦堡", "NIULUNBAO");
	arriveCityArray[115] = new Array("115", "帕德博恩", "PADEBOEN");
	arriveCityArray[116] = new Array("116", "萨尔布吕肯", "SAERBULVKEN");
	arriveCityArray[117] = new Array("117", "斯图加特", "SITUJIATE");
	arriveCityArray[118] = new Array("118", "格拉茨", "GELACI");
	arriveCityArray[119] = new Array("119", "因斯布鲁克", "YINSIBULUKE");
	arriveCityArray[120] = new Array("120", "克拉根福特", "KELAGENFUTE");
 window.onload = function(){
   $quickQuery(arriveCityArray);
  }
 </script>
  </head>
  
  <body>
    <input class="quickQuery$focus" id="q1" style="border: 3px solid #ccc;" />
    <input class="TTT quickQuery$focus" id="q2" value="北京" />
    
    <input class="quickQuery$focus ttt" id="qq" value="guang" />
    <input class="NNN quickQuery$focus ttt" id="qqq" />
    <input class="NNNquickQuery$focus" />
    
    <div class="quickQuery$focus"></div>
    <input class="NNNquickQuery$focus" type="button" />
  </body>
</html>	

二、JS

(function(){var l={container:"quickQuery_container",resultNumBox:"quickQuery_resultNum_box",contentBox:"quickQuery_content_box",pageBox:"quickQuery_page_box",ieContentFrame:"quickQuery_frame_forIE",ieContentBox:"quickQuery_content_box_forIE"};var m={exprElem:"quickQuery$focus",currentContent:"quickQuery_currentContent",currentPage:"quickQuery_currentPage",title:"quickQuery_title"};var n=document.all?true:false;var o={'isSubVal':false,'isPage':true,'subSign':"-",'buttonNum':5,'viewContentNum':15};var p={'subval':0,'hz':1,'py':2};var q=null;var r=1;var s=o['buttonNum'];var t=1;var u=[];var v=[];String.prototype.trim=function(){return this.replace(/^\s*|\s*$/g,'')};var $=function(a){return document.getElementById(a)};var w=window.$quickQuery=function(b,c){var d=[],e=[],f=null,g=null,h=true,j=null;if(b){if(c)setConfig(c);if(b.length){f=0;d=getElemArray();e=b}else{f=1;for(var k in b){if($(k)){d.push($(k));e.push(b[k])}}}d.each(function(i){var a=this;a.onfocus=a.onclick=function(){h=false;a.value="";if(a!=g){r=1;s=o['buttonNum'];t=1}getQueryPanel(a);callDifferentModel(f,a,e,i);a.focus();g=a};a.onkeyup=function(){r=1,s=o['buttonNum'],t=1;callDifferentModel(f,a,e,i)};a.onblur=function(){h=true};document.onclick=function(){clearTimeout(j);j=setTimeout(function(){if(h)closeQueryPanel()},10)}})}};function callDifferentModel(a,b,c,i){if(a==0){bindDataAndGetHtml(b,c)}else if(a==1){bindDataAndGetHtml(b,c[i])}};function bindDataAndGetHtml(a,b){putDataIntoArray(a.value.trim(),b);bindDataIntoElements(function(){if(n){$(l.ieContentFrame).style.width=$(l.ieContentBox).offsetWidth+"px";$(l.ieContentFrame).style.height=$(l.ieContentBox).offsetHeight+"px"}})};function setConfig(a){for(var b in a){o[b]=a[b]}};Array.prototype.each=function(a){for(var i=0;i<this.length;i++)a.call(this[i],i)};function getQueryPanel(a){q=a;if(!$(l.container)){var b=document.createElement("div");b.id=l.container;q.parentNode.appendChild(b);var c='<div id='+l.resultNumBox+'></div>';var d='<div id='+l.contentBox+'></div>';var e='<div id='+l.pageBox+'></div>';if(!n){b.innerHTML=c+d+e}else{var f='<iframe id='+l.ieContentFrame+' frameborder="0"></iframe>';var g='<div id='+l.ieContentBox+'>'+c+d+e+'<div>';b.innerHTML=f+g}}else{show($(l.container))}setPanelStyle()};function setPanelStyle(){q.style.position="absolute";$(l.container).style.position="absolute";$(l.container).style.left=q.offsetLeft+"px";$(l.container).style.top=q.offsetTop+q.offsetHeight-(n?1:2)+"px";$(l.container).style.zIndex=99;q.style.position="";if(n){$(l.container).style.border="none"}};function putDataIntoArray(a,b){u=[];try{var c=RegExp("^"+a,"gi");for(var i=0;i<b.length;i++){var d=c.test(b[i][p['hz']]),f=c.test(b[i][p['py']]);if(d||f){u.push(b[i])}}}catch(e){}};function bindDataIntoElements(a){var b=u.length,c=0,d=b;var e=t*o['viewContentNum'],f=e-o['viewContentNum']+1;if(!o['isPage']){e=b}if(o['isPage']&&e>=b){e=u.length}$(l.resultNumBox).innerHTML="<b>Result: "+b+"</b>";if(e!=0&&e!=1){$(l.resultNumBox).innerHTML+="  ( <i>"+f+" - "+e+"</i> )"}if(o['isPage']){d=(b<o['viewContentNum'])?b:o['viewContentNum'];if(t!=1){c=(t-1)*o['viewContentNum'];d=c+o['viewContentNum']}getPageViewContentHtml(c,(c+o['viewContentNum']));getPageControlHtml(b)}else{getPageViewContentHtml(c,d)}if(!o['isPage']||b<o['viewContentNum']){hide($(l.pageBox))}else{show($(l.pageBox))}if(typeof a=="function"){a.call(this)}};function getPageViewContentHtml(a,b){if(u.length<a){a=u.length-o['viewContentNum'];b=u.length}if(a<0){a=0;b=o['viewContentNum']}var c='<ul>';for(var i=a;i<b;i++){if(u[i]){var d=u[i][p['subval']],e=u[i][p['hz']],f=u[i][p['py']],g='<span class='+m.title+'>'+e+'</span>'+f+'';var h=e;if(o['isSubVal'])h=e+o['subSign']+d;c+='<li><a href=javascript:$query_getClickValue("'+h+'");>'+g+'</a></li>'}else{c+='<li> </li>'}}c+='</ul>';$(l.contentBox).innerHTML=c};function getPageControlHtml(a){$(l.pageBox).innerHTML="";if(a>o['viewContentNum']){var b=a/o['viewContentNum'];if(/\./.test(b)){b=Math.floor(b+=1)}if(b>o['buttonNum']){if(r>=o['buttonNum']){$(l.pageBox).innerHTML+='<span><a href=javascript:$query_prevRound();><<</a></span>'}var c=r,d=s;if(u.length<o['viewContentNum']*t){d=b}if(d>b){d=b}getCurrentPageControl(c,d);if(d<b&&(u.length>o['viewContentNum']*t)){$(l.pageBox).innerHTML+='<span><a href=javascript:$query_nextRound();>>></a></span>'}}else{getCurrentPageControl(1,b)}}else $(l.pageBox).innerHTML=""};function getCurrentPageControl(a,b){for(var i=a;i<=b;i++){if(t==i){$(l.pageBox).innerHTML+='<span><a class='+m.currentPage+' href=javascript:$query_topage("'+i+'");>'+i+'</a></span>'}else{$(l.pageBox).innerHTML+='<span><a href=javascript:$query_topage("'+i+'");>'+i+'</a></span>'}}};var x=window.$query_getClickValue=function(a){q.value=a;closeQueryPanel()};var y=window.$query_topage=function(a){t=a;q.focus();bindDataAndGetHtml(q,u)};var z=window.$query_prevRound=function(){r=r-o['buttonNum'];s=s-o['buttonNum'];t=r;q.focus();bindDataAndGetHtml(q,u)};var A=window.$query_nextRound=function(){r=r+o['buttonNum'];s=s+o['buttonNum'];t=r;q.focus();bindDataAndGetHtml(q,u)};function closeQueryPanel(){hide($(l.container))};function show(a){if(a)a.style.display="block"};function hide(a){if(a)a.style.display="none"};function getElemArray(){var a=[],b=document.getElementsByTagName("*")||document.all,c=/input/i,d=/text/i;for(var i=0;i<b.length;i++){if(c.test(b[i].tagName)&&d.test(b[i].type)){var e=b[i].className.split(' ');for(var j=0;j<e.length;j++){if(e[j]==m.exprElem)a.push(b[i])}}}return a}})();

 

三、CSS

    无法上传,可以下载

分享到:
评论

相关推荐

    拼音汉字模糊匹配字库(仿google和百度搜索引擎字词库)

    它模仿了Google和百度搜索引擎内部可能采用的技术或方法来实现汉字与拼音之间的转换及匹配功能。这种技术在中文搜索引擎、输入法、语音识别等领域具有广泛的应用价值。 #### 描述分析 描述部分提到该字库包含超过2...

    .NET实现汉字转拼音

    在.NET框架中,实现汉字转拼音是一项常见的任务,特别是在处理文本数据、语音识别、搜索引擎优化等领域。这个功能的实现主要依赖于.NET Framework提供的System.Speech库或者第三方库,如Pinyin4Net等。下面我们将...

    Java实现中文转拼音.rar

    例如,搜索引擎可以将关键词的拼音与索引中的拼音进行匹配,提高搜索准确性;在输入法中,用户输入的汉字可以通过拼音匹配候选词;还可以用于生成便于计算机处理的拼音化文本,如关键词分析、自然语言处理等。 需要...

    汉字获取拼音不带音标

    总的来说,处理汉字与拼音的转换是一项实用的技能,在自然语言处理、文本分析、搜索引擎优化等场景中都有其应用。在Delphi中,借助第三方库或自定义算法,我们可以有效地完成汉字获取拼音不带音标的需求。

    将汉字转换为汉语拼音java实现

    在Java编程语言中,将汉字转换为汉语拼音是一项常见的任务,尤其在自然语言处理、文本分析和搜索引擎优化等领域。这个程序可能使用了Java的API和第三方库来完成这个功能。以下是一些关于如何在Java中实现汉字转拼音...

    用jpinyin项目实现汉字转拼音

    在IT领域,有时候我们需要将汉字转换为拼音,这在处理中文数据、语音识别或搜索引擎优化等方面具有广泛应用。本文将深入探讨如何使用开源项目`jpinyin`来实现这一功能。`jpinyin`是一个Java库,专门设计用于将汉字...

    汉字转拼音带调操作简单,使用方便

    汉字转拼音带调技术的应用范围广泛,不仅在语音合成、搜索引擎优化、自动文本校对和语音识别等领域大放异彩,还在语言学习、教育辅助、跨文化交流等方面显示出巨大的实用价值。例如,在教育领域,该技术可以帮助学习...

    汉字转拼音,全拼带声调代码

    在IT领域,汉字转拼音是一项常见的任务,尤其在自然语言处理、搜索引擎优化、语音识别等方面有着广泛应用。本文将深入探讨如何使用C#编程语言实现汉字转拼音功能,并且重点讲解如何生成全拼带声调的代码,同时提供对...

    将中文转拼音,带音标/不带音标/获取拼音首字母

    在IT领域,中文转拼音是一项常见的任务,尤其在文本处理、搜索引擎优化(SEO)和自然语言处理(NLP)中有着广泛的应用。本教程将详细讲解如何使用JavaScript来实现中文转拼音,包括带音标、不带音标以及获取拼音首...

    java后台汉字转拼音

    在实际开发中,汉字转拼音可以应用于多个领域,比如搜索引擎的关键词提取、文本分析、语音识别等。通过了解和熟练运用这些工具,开发者可以更好地处理中文数据,提升应用的功能和用户体验。这个"java后台汉字转拼音...

    实用汉字转拼音

    在IT领域,汉字转拼音是一项重要的技术,尤其在自然语言处理、搜索引擎优化、语音识别以及中文输入法等领域有着广泛的应用。本程序名为“实用汉字转拼音”,它提供了一个方便的解决方案,可以将任意汉字转化为对应的...

    C# 汉字转拼音+源码

    它能够将汉字转换为对应的汉语拼音,对于非汉字环境下的计算机处理、搜索引擎优化、语音识别、机器翻译等领域具有重要意义。C#作为.NET框架下广泛使用的编程语言,提供了多种实现汉字转拼音的方法。 首先,我们需要...

    pinyin4j-2.5.0.jar 下载 java汉字转拼音 jar包 附带超级简单小dome

    在搜索引擎中,将关键词转化为拼音可以提高模糊匹配的效率。 pinyin4j还支持处理多音字和未登录词(即未收录在标准字典中的词汇),它会尽可能提供最接近的拼音结果。此外,pinyin4j还提供了获取汉字声母、韵母和...

    汉子转拼音

    汉字转拼音是计算机处理中文文本时的一个重要技术,它能够将汉字转化为对应的汉语拼音,方便进行文本分析、语音合成、搜索引擎优化等多种应用。这个程序包含了完成这一功能所需的库和资源,使用者可以参考来实现自己...

    C#汉字转拼音类库NPinyin附带使用说明及实例

    在.NET开发环境中,处理汉字转拼音的需求时常出现,特别是在进行语音识别、搜索引擎优化、或者面向非中文用户的界面设计时。为此,开发者们需要一个高效且准确的汉字转拼音工具。本文将深入探讨C#中的NPinyin类库,...

    asp.net 中文和拼音的相互转换

    在IT领域,中文和拼音之间的转换是常见的需求,特别是在文本处理、搜索引擎优化(SEO)、语音识别和自然语言处理(NLP)中。ASP.NET是一个强大的Web应用程序开发框架,由Microsoft提供,它允许开发者构建功能丰富的...

    C#实现汉字转换为拼音缩写的代码

    在C#编程中,有时我们需要将汉字转换为其拼音表示,特别是在处理中文文本的搜索、排序或简化...这种简单的方法适用于基础的拼音转换需求,但对于复杂的应用场景,如语音识别或搜索引擎优化,可能需要更强大的解决方案。

    易语言模块汉字转拼音.rar

    也可以用于搜索引擎的关键词提取,将汉字转换为拼音后进行索引,提高搜索效率;还可以用于输入法的候选词生成,帮助用户更快地找到想要输入的汉字。 这个"易语言模块汉字转拼音"可能包括以下功能: 1. 单个汉字转...

    C#汉字转拼音(npinyin)将中文转换成拼音全文或首字母

    开发者可以通过简单的调用来实现汉字到拼音的转换,如`NPinyin.PinyinHelper.GetFullPinyin("汉字")`来获取汉字的全拼。 在实际应用中,"npinyin"库可能用于以下场景: - **搜索引擎优化**:创建基于拼音的搜索...

Global site tag (gtag.js) - Google Analytics