1.模仿大型网站自动提示,就是输入“苹果”,在水果类中搜索,html代码如下:

<div  id="searchTips" style="display:none;width:291px;height:auto;position:absolute;z-index:9001;">
<ul></ul>
<input type="hidden" id="hidSearchOption" />
</div>

js代码如下:

    //显示搜索下拉选择项
function showTips(searchInput) {
var top = searchInput.offsetTop+32;
var left = searchInput.offsetLeft;
var width = searchInput.offsetWidth;
var ulStringFormat = "<li onclick='selectOption(this)' onmouseover='javascript:this.style.backgroundColor=\"#A9A9A9\"' onmouseout='javascript:this.style.backgroundColor=\"#666666\"' style='width:220px;height:25px;background-color: #666666;display:block;'><span style='float:left;text-indent:6px'>" + $("#searchvalue").val() + "</span><span id='{0}' style='float:right;padding-right:1px;fond-size:10px;'>{1}</span></li>";
while (searchInput = searchInput.offsetParent) {
top += searchInput.offsetTop;
left += searchInput.offsetLeft;
}
if ($("#searchvalue").val().length > 0) {
$("#searchTips").css({ "left": left + "px", "top": top + "px" }).show();
$("#searchTips>ul").empty().append(kendo.format(ulStringFormat, "sFlightNo","航班号")).append(kendo.format(ulStringFormat, "sTailNo", "机号"));
}
else {
searchInputBlur();
}
}
function fillvalue(value) {
alert($(value).find("span:first").html());
searchInputBlur();
}
function searchInputBlur() {
$("#searchTips").hide();
}
function selectOption(li) {
$("#hidSearchOption").val(($(li).find("span:last").attr("id")));
searchInputBlur();
}
//搜索
function searchContent() {
var url = "/Manager/DutyManager?BeginTime=" + getTodayBeginUTCTime() + "&EndTime=" + getTodayEndUTCTime()
var option = $("#hidSearchOption").val();
var value = $("#searchvalue").val().trim();
switch (option) {
case "sFlightNo":
url += "&FlightNo=" + value;
break;
case "sTailNo":
url += "&TailNo=" + value;
default:
}
openWindow(url);
}

效果图如下

2.带上下左右键的

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>SimulateUpDownKeySelect.html</title>
<style type="text/css">
#divSelect {border:1px solid red; width:208px !important;width:210px;}
#divSelect ul {width:200px;margin:3px; margin-left:-35px;*margin-left:3px;overflow:hidden}
#divSelect ul li {float:left; list-style-type:none;width:45px;height:14px;line-height:20px;font:14px arial;text-align:center;padding:2px}
#divSelect li:hover {background :green;cursor:pointer}
#txtInput {width:205px;}
</style>
</head>
<body>
<form method="post" action="##">
<input type="text" id="txtInput" value="" autocomplete="off" onkeydown="if(event.keyCode==13)return false;" />
<!--
防止回车键触发表单提交
onKeyPress
-->
<div id="divSelect">
</div>
<script type="text/javascript">
var list = "<ul>"
list += "<li>123a</li><li>战争片</li><li>动作片</li><li>爱情片</li><li>剧情片</li><li>记录片</li><li>fbac</li><li>bbca</li><li>defe</li><li>gzza</li><li>恐怖片</li><li>古装片</li><li>电视剧</li><li>读书</li><li >小说</li><li>作品集</li><li>历史</li><li>诗歌</li><li >散文</li><li>军事</li>";
list += "</ul>"
document.getElementById('divSelect').innerHTML = list;
</script>
</form>
<script type="text/javascript">
function $(sId) {
return document.getElementById(sId);
}
function clearSelectedOptBgColor(target) {
if (target.seletedIndex >= 0)
target.options[target.seletedIndex].style.background = "";
}
function setSelectedOptBgColor(target) {
target.options[target.seletedIndex].style.background = "green";
}
var upKeyCode = 38;
var downKeyCode = 40;
var enterKeyCode = 13;
var oInput = $("txtInput");
oInput.options = $("divSelect").getElementsByTagName("li");
oInput.seletedIndex = -1;
oInput.focus();
//oInput.onKeyPress{}
oInput.onkeyup = function (event) {
if (event == undefined)
event = window.event;
switch (event.keyCode) {
case 37:
clearSelectedOptBgColor(this);
this.seletedIndex--;
if (this.seletedIndex < 0)
this.seletedIndex = this.options.length - 1;
this.value = this.options[this.seletedIndex].innerHTML;
setSelectedOptBgColor(this); break;
case 38:
clearSelectedOptBgColor(this);
this.seletedIndex = this.seletedIndex - 4;
if (this.seletedIndex < 0)
this.seletedIndex = this.options.length - 1;
this.value = this.options[this.seletedIndex].innerHTML;
setSelectedOptBgColor(this); break;
case 39:
clearSelectedOptBgColor(this);
this.seletedIndex++;
if (this.seletedIndex >= this.options.length)
this.seletedIndex = 0;
this.value = this.options[this.seletedIndex].innerHTML;
setSelectedOptBgColor(this);
break;
case 40:
clearSelectedOptBgColor(this);
this.seletedIndex = this.seletedIndex + 4;
if (this.seletedIndex >= this.options.length)
this.seletedIndex = 0;
this.value = this.options[this.seletedIndex].innerHTML;
setSelectedOptBgColor(this);
break;
case enterKeyCode:
this.value = this.options[this.seletedIndex].innerHTML;
//alert('aa')
break;
}
};
oInput.onblur = function () {
clearSelectedOptBgColor(this);
this.seletedIndex = 1;
};
</script>
</body>
</html>

效果:

3.下面这个只带上下键提示,写的比较规范

<head>
<title></title>
<style type="text/css">
#autoCompleteWp
{
border: 1px solid #ddd;
padding: 20px;
margin: 100px auto;
width: 300px;
position: relative;
}
#datalist
{
position: absolute;
left: 0;
top: 56px;
background: #f8f8f8;
z-index: 2;
border: 1px solid #FCC;
padding: 15px;
display: none;
}
#datalist li
{
line-height: 1.6;
list-style: none;
cursor: pointer;
}
.on
{
background: #06C;
color: #fff;
}
</style>
</head>
<body>
<div id="autoCompleteWp">
请输入邮箱:<br />
<input id="autoComplete" type="text" />
<ul id="datalist">
</ul>
</div>
<script type="text/javascript">
var $ = function (id) {
return "string" == typeof id ? document.getElementById(id) : id;
};
var Class = {
create: function () {
return function () { this.initialize.apply(this, arguments); }
}
}
function addEventHandler(oTarget, sEventType, fnHandler) {
if (oTarget.addEventListener) {
oTarget.addEventListener(sEventType, fnHandler, false);
} else if (oTarget.attachEvent) {
oTarget.attachEvent("on" + sEventType, fnHandler);
} else {
oTarget["on" + sEventType] = fnHandler;
}
};
function removeEventHandler(oTarget, sEventType, fnHandler) {
if (oTarget.removeEventListener) {
oTarget.removeEventListener(sEventType, fnHandler, false);
} else if (oTarget.detachEvent) {
oTarget.detachEvent("on" + sEventType, fnHandler);
} else {
oTarget["on" + sEventType] = null;
}
}
String.prototype.trim = function () {
return this.replace(/^\s+|\s+$/g, '');
}
//自动完成类
var autoComplete = Class.create();
autoComplete.prototype = { initialize: function (obj, databox, data) {
_this = this;
this.input = $(obj);
this.data = data;
this.index = 0;
this.datalist = $(databox).getElementsByTagName('li');
addEventHandler(this.input, 'keyup', this.writting);
},
writting: function (e) {
var e = e || window.event;
var keyCode = e.keyCode || e.charCode; //兼容ie firefox等事件 switch (keyCode) { case 38: //上
_this.index--;
if (_this.index < 0) {
_this.index = $('datalist').getElementsByTagName('li').length - 1
} if ($('datalist').getElementsByTagName('li').length > 0) { for (var k = 0; k < $('datalist').getElementsByTagName('li').length; k++) {
$('datalist').getElementsByTagName('li')[k].className = ''
}
}
$('datalist').getElementsByTagName('li')[_this.index].className = "on";
break;
case 40:
_this.index++;
if (_this.index > $('datalist').getElementsByTagName('li').length - 1) {
_this.index = 0;
}
if ($('datalist').getElementsByTagName('li').length > 0) {
for (var k = 0; k < $('datalist').getElementsByTagName('li').length; k++) {
$('datalist').getElementsByTagName('li')[k].className = ''
}
}
$('datalist').getElementsByTagName('li')[_this.index].className = "on"
break;
//回车
case 13:
_this.input.value = $('datalist').getElementsByTagName('li')[_this.index].innerHTML.replace(/<\/?strong>/gi, '') //获取html,正则过滤标签,只取其值
$('datalist').style.display = 'none'
break;
default:
var temp = [];
var val = _this.input.value.trim();
if (val == '') {
$('datalist').style.display = 'none'
return;
}
//如果输入字符包含\会导致正则表达式出错,转换成\\即可 [ ] 等也需要转义
if (val.indexOf('\\') != -1) {
val = val.replace(/\\/g, '\\\\')
}
var reg = new RegExp('^(' + val + ')');
//利用正则把匹配到的数据 加入数组
for (var i = 0; i < _this.data.length; i++) {
//如果匹配到
if (reg.test(_this.data[i])) {
thedata = _this.data[i].replace(reg, '<strong>$1</strong>'); //利用js正则式中replace中的占位符特性
temp.push('<li title="' + i + '">' + thedata + '</li>')
}
else {
$('datalist').style.display = 'none'
}
}
//如果匹配到数据
if (temp.length > 0) {
$('datalist').innerHTML = temp.join('');
$('datalist').style.display = 'block';
var li = $('datalist').getElementsByTagName('li');
li[0].className = "on";
_this.index = 0;
for (var i = 0; i < li.length; i++) {
li[i].onmouseover = function () {
for (var i = 0; i < li.length; i++) {
li[i].className = '';
}
this.className = 'on';
_this.index = this.getAttribute('title');
}
//鼠标点击
li[i].onclick = function () {
_this.input.value = this.innerHTML.replace(/<\/?strong>/gi, '') //获取html,正则过滤标签,只取其值
$('datalist').style.display = 'none'
}
}
}
else {
$('datalist').innerHTML = '';
}
break;
}
}
}
var data = ['yaofjaa@vip.qq.com', 'yaojaa008@163.com', 'yaojaa@yahoo.com', 'yaoj4aa@sohu.com.com', 'yaojaa@vipf.qq.com', 'yfaojaa@163.com', 'yaojfaa@sina.com', 'yaojaa@yahoo.com', 'yaojaa@sohu.com']
var auto = new autoComplete('autoComplete', 'datalist', data)
</script>
</body>
</html>

效果如下:

js文本框提示和自动完成的更多相关文章

  1. [js开源组件开发]js文本框计数组件

    js文本框计数组件 先上效果图: 样式可以自行调整 ,它的功能提供文本框的实时计数,并作出对应的操作,比如现在超出了,点击下面的按钮后,文本框会闪动两下,阻止提交.具体例子可以点击demo:http: ...

  2. 转:zTree树控件扩展篇:巧用zTree控件实现文本框输入关键词自动模糊查找zTree树节点实现模糊匹配下拉选择效果

    是否可以借助于zTree实现文本框输入关键词自动模糊匹配zTree下拉树,然后选择下拉树内节点显示在文本框内且隐藏下拉树. 看到这个需求脑子里头大致已经想到了要如何实现这样一个需求,当时是限于时间问题 ...

  3. cognos report利用文本框提示优化日期维度

    为了尽量减少手工对日期维度的维护,在日期维度表中年份已经到了2099年,把年份作为下拉框或者月份作为下拉框的时候,选择起来颇为麻烦(当然也可以在此基础之上设置默认为当前月) 如图:提示页面以及html ...

  4. (转)完美解决 Android WebView 文本框获取焦点后自动放大有关问题

    完美解决 Android WebView 文本框获取焦点后自动放大问题 前几天在写一个项目时,要求在项目中嵌入一个WebView 本来很快就完成了,测试也没有问题.但发给新加坡时,他们测试都会出现文本 ...

  5. html5文本框提示文字属性为placeholder

    html5文本框提示文字属性为placeholder 例子:  <textarea id="comment" class="commentCont"  n ...

  6. WEB文本框提示

    <input type="text" placeholder="文本框提示语" name="version_no"/>

  7. 目录视图摘要视图订阅 基于Extjs开发不允许为空的文本框提示及相应的验证错误提示(转)

    原文地址:http://blog.csdn.net/kunoy/article/details/8007585 本文主要解决问题: 1.区分哪些文本框不允许为空,很多网站都采用在文本框后加*号,ext ...

  8. input文本框录入字母自动大写

    向文本框输入文字时,如何让小写字母自动变为大写呢?有一个简单有效的做法是用CSS. <input name="t1" type="text" style= ...

  9. Android实现Filterable通过输入文本框实现联系人自动筛选

    相信大家一定在见过手机通讯录的一个情景就是使用在选人的时候输入文本框里的数据就能自动筛选.实现的效果如下图. 其实实现这样的效果相信大家一定对另外一个控件不陌生那就AutoCompleteTextvi ...

随机推荐

  1. Vue中class与style绑定

    gitHub地址:https://github.com/lily1010/vue_learn/tree/master/lesson07 一 用对象的方法绑定class 很简单,举个栗子: <!D ...

  2. Winform使用外部浏览器解决webbrowser问题

    对于还是一个菜鸟的我,在最近自己接手了个项目,搞的自己也是醉了,身边也有没大神的现场指导,只能靠度娘和谷歌的大力帮助,要不然这么个小项目可定现在还交不了,不过在这过程种也确确实实学到了不少东西,我先说 ...

  3. Android项目实战(二):安卓应用程序退出的三种方法

    现在的APP退出的时候都不是让用户点击了“后退键”就退出.防止用户点错了后退键而造成的用户体检不好. 一年前搞的Demo代码不见了,重新写下就当是复习和以后直接拿来用把 目前流行的解决一般分为两种: ...

  4. C语言-07-预处理、typedef、static和extern

    预处理 1> 使用注意 以#开头 在代码被翻译成0和1之前执行 预处理指令可以出现在任何位置 作用域是从编写指令那一行开始到文件结束 2> 宏定义 基本使用 ① 使用#define定义 ② ...

  5. C语言-04-函数

    函数 函数是一组一起执行任务的语句,函数是一个可执行C程序必不可少的条件(至少一个main()函数),函数的定义形式 returnType functionName() { bodyOf of the ...

  6. Monyer's Game 6~10关过关方法

    从Monyer's Game开通到现在,已经有50多人通关了.其中绝大部分人,不管是自己独立完成也好,参考别人也罢,都是自己一步一步过去的.像陆羽兄弟甚至已经为游戏做好了整个通关的教程,在此Monye ...

  7. oracle REGEXP_SUBSTR函数

    REGEXP_SUBSTR函数格式如下: function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier) __srcst ...

  8. 你真的说的清楚ArrayList和LinkedList的区别吗

    参见java面试的程序员,十有八九会遇到ArrayList和LinkedList的区别?相信很多看到这个问题的人,都能回答个一二.但是,真正搞清楚的话,还得花费一番功夫. 下面我从4个方面来谈谈这个问 ...

  9. emacs24下使用jedi对python编程进行补全

    在开始前先装好pip和virtualenv(见pip的安装一文),另需安装好make 1.emacs下安装: epc deferred.el auto-complete 使用M-x package-i ...

  10. Windows 网络问题

    一.问题描述 每次重启后电脑的ip地址或无故没掉,或不能正常连网,要重新设置ip才能上网.   二.解决方法 在DOS窗口执行 netsh winsock reset netsh int ip res ...