- 浏览: 141571 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
puyancheng1988:
哥们儿,我用的jfreechart在linux服务器上生成的图 ...
JFreeChart图表 -
soujava:
...
Linux下Oracle自动备份脚本 -
skylikeblue:
...
基于JAVA实现的手机收发短消息系统
FireFox与IE的小小注意:
1、firefox记得宽度和高度加‘p ’
2、firefox事件用obj.addEventListener("input",test1,false);
3、事件源与event对象。
event.srcElement和event.target
event和window.event
类似GOOGLE实现下拉框列表提示代码:
<!-- style显示控制医院列表 -->
<style>
span
{
text-align:left;
font-size:12px;
width: 200px;
}
span.spanTextDropdown{
position: absolute;
top: 0px;
left: 0px;
width: 200px;
z-index: 101;
background-color: #ffffff;
border: 1px solid #000000;
padding-left: 2px;
overflow: visible;
display: none;
}
span.spanMatchText{
text-decoration: underline;
font-weight: bold;
}
span.spanNormalElement{ background: #ffffff; }
span.spanHighElement{
background: #FF99CC;
color: #0000FF;
cursor: pointer;
}
</style>
<!-- style显示控制结束 -->
//DOWNLIST.JS
var arrOptions = new Array();
var theTextBox;
var isSure=0;
//表当前选中的某项
var currentValueSelected = -1;
//以上设置一些全局变量
window.onload = function()
{
//在页面创建span标签
var elemSpan = document.createElement("span");
elemSpan.id = "spanOutput";
elemSpan.className = "spanTextDropdown";
document.body.appendChild(elemSpan);
//当按键抬起调用此函数
if(isIE())
{
$("hospital").onkeyup=test1;
$("hospital").onpropertychange=test1;
}
else
{
$("hospital").addEventListener("input",test1,false);
$("hospital").addEventListener("keyup",test1,false);
}
}
function show(){alert("evet");}
function isIE()
{
if(navigator.appName.indexOf("Explorer")>-1) return true;
else return false;
}
function $(id){ return document.getElementById(id);}
function clearOptions(ctl)
{
for(var i=ctl.options.length-1;i>0;i--){ctl.remove(i);}
}
function getKesi(hos)
{
linkage.getSS(hos,function(returnvalue)
{
for(var i=0; i<returnvalue[0].length; i++)
{
document.getElementById("office").options.add(new Option(returnvalue[1][i],returnvalue[0][i]));
}
});
}
function test1(evt)
{
var intKey = -1;
var temp="";
var evt=evt?evt:(window.event?window.event:null);
if(evt)
{
intKey = evt.keyCode;
//获得事件源
theTextBox = evt.srcElement?evt.srcElement:evt.target;
}
clearOptions(document.getElementById("office"))
if(isSure==1){isSure=-1;return false;}
else
{
if(isSure<0) isSure=0;
else
{
if(theTextBox.value.length == 0)
{
HideTheBox();
return false;
}
if(intKey == 13){
//按回车键
SetText();
theTextBox.blur();
return false;
}else if(intKey == 38){
//按向上键
MoveHighlight(-1);
return false;
}else if(intKey == 40){
//按向下键
MoveHighlight(1);
return false;
}
var vau=$("hospital").value;
if(vau=="输入医院进行选择" || vau==null) vau="";
//dwr技术,后台连接数据库
linkage.getHosByHNameAndArea(
vau,
$("aname").value,
function(datas)
{
arrOptions=datas;
//建立下拉框
Bulid(arrOptions);
}
);
}
}
}
function Bulid(arrOptions)
{
var inner="";
//设置下拉框出现的位置
SetElementPosition();
var i=0;
for(var i=0;i<arrOptions.length;i++)
{
inner+="<span id=arr_"+i+" class='spanNormalElement' onmouseover='SetHighColor(this)' onclick='SetText()'><font color='#0000FF'>"+arrOptions[i].HName+"</font></span><br>";
}
document.getElementById("spanOutput").innerHTML = inner;
if(inner!="")
{
//设置第一个顶为默认选中
document.getElementById("arr_0").className ="spanHighElement";
currentValueSelected=0;
}
else
{
HideTheBox();
currentValueSelected=-1;
}
}
function SetElementPosition()
{
//设置下拉框出现的位置
var selectedPosX = 0;
var selectedPosY = 0;
var theElement = $("hospital");
var theTextBoxInt = $("hospital");
if (!theElement) return;
var theElemHeight = theElement.offsetHeight;
var theElemWidth = theElement.offsetWidth;
while(theElement != null)
{
selectedPosX += theElement.offsetLeft;
selectedPosY += theElement.offsetTop;
theElement = theElement.offsetParent;
}
xPosElement = document.getElementById("spanOutput");
if(isIE())
{
xPosElement.style.left = selectedPosX;
xPosElement.style.width = theElemWidth;
xPosElement.style.top = selectedPosY + theElemHeight
xPosElement.style.display = "block";
}
else
{
xPosElement.style.left = selectedPosX+'px';
xPosElement.style.width = theElemWidth+'px';
xPosElement.style.top = selectedPosY + theElemHeight+'px';
xPosElement.style.display = "block";
}
}
function MoveHighlight(xDir)
{
//设置上下移动键
var currnum=currentValueSelected+xDir;
if(currnum >= 0 && currnum<arrOptions.length )
{
document.getElementById("arr_"+currentValueSelected+"").className ="spanNormalElement";
document.getElementById("arr_"+currnum+"").className ="spanHighElement";
currentValueSelected=currnum;
}
else if(currnum==arrOptions.length)
{
document.getElementById("arr_"+currentValueSelected+"").className ="spanNormalElement";
currentValueSelected=0;
document.getElementById("arr_"+currentValueSelected+"").className ="spanHighElement";
}
else if(currnum==-1)
{
document.getElementById("arr_"+currentValueSelected+"").className ="spanNormalElement";
currentValueSelected=arrOptions.length-1;
document.getElementById("arr_"+currentValueSelected+"").className ="spanHighElement";
}
}
function HideTheBox()
{
//隐藏下拉框
document.getElementById("spanOutput").style.display = "none";
currentValueSelected = -1;
}
function SetText()
{
//选中下拉框中的某个值
isSure=1;
theTextBox = $("hospital");
theTextBox.value = arrOptions[currentValueSelected].HName;
document.getElementById("spanOutput").style.display = "none";
$("hospital").value=theTextBox.value;
$("hos").value=theTextBox.value;
getKesi(theTextBox.value);
currentValueSelected = -1;
}
function SetHighColor(theTextBox)
{
//当鼠标划过变为选中状态
if(theTextBox)
{
currentValueSelected = theTextBox.id.slice(theTextBox.id.indexOf("_")+1,theTextBox.id.length);
}
for(var i = 0; i < arrOptions.length; i++)
{
document.getElementById('arr_' + i).className ='spanNormalElement';
}
document.getElementById('arr_'+currentValueSelected).className = 'spanHighElement';
}
function FocuText()
{
$("hospital").select();
var vau=$("hospital").value;
if(vau=="输入医院进行选择" || vau==null) vau="";
//dwr技术,后台连接数据库
linkage.getHosByHNameAndArea(
vau,
$("aname").value,
function(datas){
arrOptions=datas;
//建立下拉框
Bulid(arrOptions);
}
);
}
function BlurText()
{
if($("hospital").value=="") $("hospital").value="输入医院进行选择";
}
<script type='text/javascript' src='dwr/interface/linkage.js'></script>
<script type='text/javascript' src='dwr/engine.js'></script>
<script type='text/javascript' src='dwr/util.js'></script>
<script type='text/javascript' src='js/downlist.js'></script>
<input type="text" name="hospital" id="hospital" value="输入医院进行选择" onFocus="FocuText();" onBlur="BlurText();" size="30" maxlength="100"/>
发表评论
-
使用JQuery 简化Ajax 开发
2008-10-07 10:20 624jQuery 是什么? jQuery 由 John ... -
DTree的BUG解决方法
2008-12-25 15:33 991dtree.js的BUG当dtree条目的URL包括空格时,浏 ... -
JS常用正规表达式
2009-08-07 09:39 1180^ 匹配一个输入或一行 ... -
身份证验证算法
2008-03-05 16:29 795公民身份号码是特征组合码,由十七位数字本体码和一位数字校验 ... -
ajax缓存解决办法
2008-03-06 14:03 712有三种办法: 1、加个随机数 xmlHttp.open(&q ... -
基础的prototype.js常用函数及其用法
2008-03-06 15:49 676prototype.js 常用函数 : Element.t ... -
prototype源码中文说明
2008-03-06 15:57 645/** * 定义一个全局对 ... -
javascript replace方法与正则表达式
2008-03-13 17:52 680replace方法的语法是:str ... -
网页Tab选项卡实现
2008-06-28 19:58 785<style type="text/css&q ... -
网页中LRC歌词同步显示
2008-06-30 13:11 1080<html><head> < ... -
dojo之djConfig详解
2008-06-30 15:55 765djConfig是dojo内置的一个全局设置对象,其作用是可以 ... -
dojo验证函数
2008-06-30 16:04 814dojo提供了几乎全方位的验证函数,在使用下面的方法之前,要通 ... -
常用正则表达式
2008-06-30 16:19 673下面给出一些常用正则表达式: 1、 非负整数:”^d+$” ... -
dojo对象方法
2008-06-30 17:00 760这里所说的基础对象和 ... -
dojo之ValidationTextbox
2008-06-30 17:04 901功能强大的文本框:dijit.form.ValidationT ... -
dojo之IO和BrowserIO
2008-06-30 17:48 754模块:dojo.io.IO dojo.io.bind 处理请求 ... -
JavaScript中创建对象
2008-08-19 09:04 654注意以下两点:1、在对象的方法内调用其他方法时,别忘记了要加t ... -
AJAX实践DWR篇
2008-08-19 09:06 846DWR(Direct Web Remoting)是一个WEB远 ... -
FckEditor V2.6 fckconfig.js中文注释
2008-08-22 16:14 848FckEditor V2.6 fckconfig.js中文注释 ... -
FCKeditor使用详解
2008-08-22 16:36 758首先,FCKEDITOR的性能是非常好的,用户只需很少的时间 ...
相关推荐
总的来说,实现类似Google的下拉框控件需要结合JavaScript、Ajax、XML(或JSON)和后端编程(如C#)等技术,通过前端与后端的紧密协作,实现高效的智能搜索提示功能。这样的功能不仅提升了用户体验,也是现代Web应用...
标题中的"仿google,百度的下拉框提示(无刷新)"是指实现一个类似于谷歌和百度搜索引擎的自动完成功能,即在用户输入...通过这些技术的结合,可以实现一个高效的无刷新下拉框提示功能,提供类似谷歌和百度的搜索体验。
### 实现类似Google自动提示功能的关键技术点 在本文中,我们将深入探讨如何实现一个类似于Google搜索中的自动提示(Autocomplete)功能。该功能能够根据用户输入的部分字符提供相关的建议列表,极大地提升了用户...
本示例将聚焦于如何使用Ajax来实现类似Google搜索时的实时搜索提示功能。 首先,我们要理解Google搜索提示的基本原理。它通过在用户输入关键字时,向服务器发送请求,服务器根据这些关键字返回相关的搜索建议。这些...
在“bootstrap select 下拉框通过拼音搜索汉字”这个实例中,我们关注的重点是如何利用该插件实现通过输入拼音来搜索并筛选汉字的功能,这对于中文环境下的用户体验提升有着显著的作用。 首先,我们要了解Bootstrap...
在实际应用中,我们经常需要实现类似谷歌搜索那样的输入自动提示功能,即用户在输入框中输入文字时,系统能够实时给出匹配的建议。在本项目“QCombox自动提示,仿谷歌搜索功能”中,我们将看到如何结合`QComboBox`和...
在本文中,我们将探讨如何利用MFC中的CComboBox控件实现类似于百度和Google搜索的自动提示功能。在传统的MFC库中,CComboBox控件并未内置自动提示输入的功能,但通过一些技巧和自定义处理,我们可以模拟出这种效果。...
"标签"中提到了"百度"和"google",这可能意味着该源码或demo可能受到了这两个搜索引擎的启发,或者实现了类似的功能。百度和Google的搜索框都包含了可输入下拉框,能够根据用户的输入提供即时的搜索建议,大大提升了...
对于“类似Google的输入下拉提示”,可以在用户输入时,利用DWR实时向服务器发送请求,根据输入的关键词匹配数据库中的数据,然后将匹配结果以列表的形式显示在输入框下方。 在实现过程中,需要注意以下几点: 1. ...
这个项目名为"C++模仿GOOGLE等搜索引擎的智能提示功能",其目的是通过源代码实现一个类似于谷歌搜索框的自动提示系统。 首先,我们要理解“自动提示”或“自动完成”(Autocomplete)的概念。在编程领域,自动提示...
标题中的“文本输入像google的自动提示”指的是在网页中实现一种类似谷歌搜索框的自动补全功能。这种功能在用户输入文本时,能够实时显示与输入内容匹配的建议列表,提高了用户输入的效率和准确性。它基于 AJAX...
这种技术通常应用于搜索框、标签输入、多选下拉框等场景,允许用户通过键入部分内容来快速筛选并选择所需选项,类似于Google搜索的自动补全功能。本文将详细探讨TokenInput的工作原理、特点、应用场景以及实现方法。...
在IT行业中,构建一个搜索引擎是复杂且技术性强的任务,尤其是要实现类似谷歌这样的高效、用户友好的搜索体验。本文将详细解析"完全仿谷歌搜索 显示信息条数"这一主题,涵盖智能提示、自动回传、谷歌搜索效果的实现...
通过对这些文件的分析和整合,我们可以构建一个完整的搜索下拉提示系统,让用户在输入搜索词时获得与Google和百度类似的便捷体验。 总结来说,J2EE实现的仿Google、百度搜索下拉提示功能是一个涉及前端交互、后端...
listbox与textbox组合,实现类似google、百度搜索的模糊查询功能。textbox中输入数据,连接数据库进行模糊查找数据库记录,在将记录加载到listbox中。双击listbox中查询到的记录,再传递到testbox中显示。 希望能给...
为了实现类似的功能,我们需要关注以下几个关键点: 1. **前端设计**:前端部分需要监听用户输入,每当用户键入新的字符时,触发请求发送到服务器。同时,需要有一个合适的UI组件来显示建议列表,例如下拉框或浮层...
在Vant的组件体系中,`Field`组件主要用于表单输入,而`Autocomplete`则是用于实现自动完成功能的组件。在本案例中,我们将探讨如何将`Field`组件与自动完成功能相结合。 1. **Vant Field组件** Vant的`Field`组件...
在本文中,我们将深入探讨如何使用ASP.NET 2005和SQL数据库来实现一个类似于Google的搜索功能,包括搜索下拉框的自动提示。这个功能对于提高用户体验和提升网站互动性至关重要,尤其是在大型网站中,它能帮助用户...
"TextBox百度下拉模糊查询"和"TextBoxGoogle下拉模糊查询"是两种在前端开发中实现类似搜索引擎下拉提示功能的技术。这里我们将详细探讨这两者的核心概念、实现原理以及如何应用。 1. 模糊查询原理: 模糊查询主要...
这种功能常被称为“AJAX Suggest”或“下拉框提示”,它结合了JavaScript与AJAX技术来实现。通过这种方式,不仅能够减少用户的输入量,还能提高搜索的准确性和效率。 #### 二、关键技术解析 ##### 1. JavaScript ...