`
SteveLee
  • 浏览: 25266 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

js 实现HTML文本框实现下拉提示

阅读更多

         今天在做JS实现HTML文本框下拉提示的功能  , 在网上找到一段代码并对这段代码增加了Cookie功能。代码如下:

 

    

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>登录---文本框输入提示/自动完成功能</title>

<script type="text/javascript">
	function mSift_SeekTp(oObj, nDire) {
		if (oObj.getBoundingClientRect && !document.all) {
			var oDc = document.documentElement;
			switch (nDire) {
			case 0:
				return oObj.getBoundingClientRect().top + oDc.scrollTop;
			case 1:
				return oObj.getBoundingClientRect().right + oDc.scrollLeft;
			case 2:
				return oObj.getBoundingClientRect().bottom + oDc.scrollTop;
			case 3:
				return oObj.getBoundingClientRect().left + oDc.scrollLeft;
			}
		} else {
			if (nDire == 1 || nDire == 3) {
				var nPosition = oObj.offsetLeft;
			} else {
				var nPosition = oObj.offsetTop;
			}
			if (arguments[arguments.length - 1] != 0) {
				if (nDire == 1) {
					nPosition += oObj.offsetWidth;
				} else if (nDire == 2) {
					nPosition += oObj.offsetHeight;
				}
			}
			if (oObj.offsetParent != null) {
				nPosition += mSift_SeekTp(oObj.offsetParent, nDire, 0);
			}
			return nPosition;
		}
	}
	function mSift(cVarName, nMax) {
		this.oo = cVarName;
		this.Max = nMax;
	}
	mSift.prototype = {
		Varsion : 'v2010.10.29 by AngusYoung | mrxcool.com',
		Target : Object,
		TgList : Object,
		Listeners : null,
		SelIndex : 0,
		Data : [],
		ReData : [],
		Create : function(oObj) {
			var _this = this;
			var oUL = document.createElement('ul');
			oUL.style.display = 'none';
			oObj.parentNode.insertBefore(oUL, oObj);
			_this.TgList = oUL;
			oObj.onkeydown = oObj.onclick = function(e) {
				_this.Listen(this, e);
			};
			oObj.onblur = function() {
				setTimeout(function() {
					_this.Clear();
				}, 100);
			};
		},
		Complete : function() {
		},
		Select : function() {
			var _this = this;
			if (_this.ReData.length > 0) {
				_this.Target.value = _this.ReData[_this.SelIndex].replace(
						/\*/g, '*').replace(/\|/g, '|');
				_this.Clear();
			}
			setTimeout(function() {
				_this.Target.focus();
			}, 10);
			_this.Complete();
		},
		Listen : function(oObj) {
			var _this = this;
			_this.Target = oObj;
			var e = arguments[arguments.length - 1];
			var ev = window.event || e;
			switch (ev.keyCode) {
			case 9://TAB 
				return;
			case 13://ENTER 
				_this.Target.blur();
				_this.Select();
				return;
			case 38://UP 
				_this.SelIndex = _this.SelIndex > 0 ? _this.SelIndex - 1
						: _this.ReData.length - 1;
				break;
			case 40://DOWN 
				_this.SelIndex = _this.SelIndex < _this.ReData.length - 1 ? _this.SelIndex + 1
						: 0;
				break;
			default:
				_this.SelIndex = 0;
			}
			if (_this.Listeners) {
				clearInterval(_this.Listeners);
			}
			_this.Listeners = setInterval(function() {
				_this.Get();
			}, 10);
		},
		Get : function() {
			var _this = this;
			if (_this.Target.value == '') {
				_this.Clear();
				return;
			}
			if (_this.Listeners) {
				clearInterval(_this.Listeners);
			}
			;
			_this.ReData = [];
			var cResult = '';
			for ( var i = 0; i < _this.Data.length; i++) {
				if (_this.Data[i].toLowerCase().indexOf(
						_this.Target.value.toLowerCase()) >= 0) {
					_this.ReData.push(_this.Data[i]);
					if (_this.ReData.length == _this.Max) {
						break;
					}
				}
			}
			var cRegPattern = _this.Target.value.replace(/\*/g, '*');
			cRegPattern = cRegPattern.replace(/\|/g, '|');
			cRegPattern = cRegPattern.replace(/\+/g, '\\+');
			cRegPattern = cRegPattern.replace(/\./g, '\\.');
			cRegPattern = cRegPattern.replace(/\?/g, '\\?');
			cRegPattern = cRegPattern.replace(/\^/g, '\\^');
			cRegPattern = cRegPattern.replace(/\$/g, '\\$');
			cRegPattern = cRegPattern.replace(/\(/g, '\\(');
			cRegPattern = cRegPattern.replace(/\)/g, '\\)');
			cRegPattern = cRegPattern.replace(/\[/g, '\\[');
			cRegPattern = cRegPattern.replace(/\]/g, '\\]');
			cRegPattern = cRegPattern.replace(/\\/g, '\\\\');
			var cRegEx = new RegExp(cRegPattern, 'i');
			for ( var i = 0; i < _this.ReData.length; i++) {
				if (_this.Target.value.indexOf('*') >= 0) {
					_this.ReData[i] = _this.ReData[i].replace(/\*/g, '*');
				}
				if (_this.Target.value.indexOf('|') >= 0) {
					_this.ReData[i] = _this.ReData[i].replace(/\|/g, '|');
				}
				cResult += '<li style="padding:0 5px;line-height:20px;cursor:default;" onmouseover="'
						+ _this.oo
						+ '.ChangeOn(this);'
						+ _this.oo
						+ '.SelIndex='
						+ i
						+ ';" onmousedown="'
						+ _this.oo
						+ '.Select();">'
						+ _this.ReData[i].replace(cRegEx, function(s) {
							return s;
						});
			}
			if (cResult == '') {
				_this.Clear();
			} else {
				_this.TgList.innerHTML = cResult;
				_this.TgList.style.cssText = 'display:block;position:absolute;background:#fff;border:#090 solid 1px;margin:-1px 0 0;padding: 5px;list-style:none;font-size:12px;';
				_this.TgList.style.top = mSift_SeekTp(_this.Target, 2) + 'px';
				_this.TgList.style.left = mSift_SeekTp(_this.Target, 3) + 'px';
				_this.TgList.style.width = _this.Target.offsetWidth - 12 + 'px';
			}
			var oLi = _this.TgList.getElementsByTagName('li');
			if (oLi.length > 0) {
				oLi[_this.SelIndex].style.cssText = 'background:#36c;padding:0 5px;line-height:20px;cursor:default;color:#fff;';
			}
		},
		ChangeOn : function(oObj) {
			var oLi = this.TgList.getElementsByTagName('li');
			for ( var i = 0; i < oLi.length; i++) {
				oLi[i].style.cssText = 'padding:0 5px;line-height:20px;cursor:default;';
			}
			oObj.style.cssText = 'background:#36c;padding:0 5px;line-height:20px;cursor:default;color:#fff;';
		},
		Clear : function() {
			var _this = this;
			if (_this.TgList) {
				_this.TgList.style.display = 'none';
				_this.ReData = [];
				_this.SelIndex = 0;
			}
		}
	}
	//得到Cookies
	function getCookie(c_name)
	{
	if (document.cookie.length>0)
	  {
	  c_start=document.cookie.indexOf(c_name + "=")
	  if (c_start!=-1)
	    { 
	    c_start=c_start + c_name.length+1 
	    c_end=document.cookie.indexOf(";",c_start)
	    if (c_end==-1) c_end=document.cookie.length
	    return unescape(document.cookie.substring(c_start,c_end))
	    } 
	  }
	 return ""
	}
    //设置Cookies
	function setCookie(c_name,value,expiredays)
	{
		var exdate=new Date()
		exdate.setDate(exdate.getDate()+expiredays)
		document.cookie=c_name+ "=" +escape(value)+
		((expiredays==null) ? "" : ";expires="+exdate.toGMTString())
	}

	function checkCookie()
	{  
		var username=getCookie('username');
		var cookievalue=document.getElementById("abc").value;
	    if(username!=null&&username!=""){
             if(username.indexOf(cookievalue)<=-1){
                 username=username+","+cookievalue;
            	 setCookie('username',username,3);
             }
		}else{
			setCookie('username',cookievalue,3); 
	    }
	}    	
</script>
</head>
<body>
<form name="salefrm" method="post" action="map.html" onsubmit="checkCookie()">用户名:<input
	type="text" id="abc" name="abc" value="J" size="40" /> <input type="submit"
	value="提交" /></form>
<script type="text/javascript">
    var uname=getCookie('username');
    var arr=uname.split(',');
	var oo = new mSift('oo', 20);
	oo.Data =arr;
	oo.Create(document.getElementById('abc'));
</script>
</body>
</html>

   

 以上就是今天研究 HTML 文本框下拉提示的代码,如有问题请留言。。             

分享到:
评论

相关推荐

    javascript 文本框下拉提示与cookie应用实例

    总结来说,这个实例展示了如何使用JavaScript和CSS创建文本框下拉提示,同时利用Cookie存储用户的选择,以实现更个性化的交互体验。在实际开发中,这样的设计可以应用于搜索框、自动补全或者任何需要提供预设选项供...

    JavaScript 文本框下拉提示(自动提示)

    JavaScript 文本框下拉提示,通常被称为自动补全或自动提示功能,是许多网页和应用程序中常见的一种交互设计。这种技术允许用户在输入文本时,系统根据已输入的部分内容提供匹配建议,从而提高输入效率和用户体验。...

    前台实现文本框中c#关键字变色及提示

    本资源包提供了一个解决方案,它包含三个JavaScript文件和一个HTML文件,用于在前端实现C#关键字变色以及输入时的关键字提示功能,非常适合在线编译器或代码编辑器的开发。 首先,我们要理解C#是一种面向对象的编程...

    jquery实现autocomplete插件(文本框下拉选项).zip

    《jQuery实现Autocomplete插件:文本框下拉选项详解》 在Web开发中,用户界面的交互性与易用性是提升用户体验的关键因素之一。jQuery作为一个轻量级、功能强大的JavaScript库,为开发者提供了丰富的插件,使得创建...

    输入框下拉提示插件

    在本案例中,我们讨论的是一个基于jQuery实现的输入框下拉提示插件。 首先,让我们深入理解jQuery。jQuery是一个轻量级的JavaScript库,它简化了HTML文档遍历、事件处理、动画以及Ajax交互。jQuery的核心特性包括...

    jQuery input文本框城市下拉菜单选择代码

    本示例中,“jQuery input文本框城市下拉菜单选择代码”是关于如何使用jQuery来实现一个交互式的城市选择功能,通常用于用户在输入框中选择他们的所在城市。这种功能常见于在线表单、地址填写等场景,可以提高用户...

    文本框实现内容提示(仿Google、Baidu)

    Google和Baidu等知名搜索引擎在搜索框的设计上,引入了一种交互性的增强功能——内容提示,也被称为自动补全或下拉提示。这种功能能够根据用户输入的关键词实时显示相关建议,提高用户的输入效率和搜索体验。本文将...

    jQuery input点击文本框三级联动下拉菜单代码

    本篇文章将详细讲解如何利用jQuery实现一个输入文本框的三级联动下拉菜单功能。 首先,我们需要理解“三级联动”的概念。在网页交互中,三级联动通常指的是三个下拉菜单之间存在依赖关系,当用户在一个下拉菜单中...

    JavaScript html js页面刷新之后下拉菜单选中值不变,在按钮提交后保存下拉列表中值不变

    标题中的“JavaScript html js页面刷新之后下拉菜单选中值不变”是一个常见的前端开发问题,涉及到浏览器缓存、页面状态保持以及JavaScript操作DOM元素的知识点。在这个场景中,开发者希望在用户选择下拉菜单的一项...

    js text输入框提示火车机票网站点击文本框城市选择

    在构建火车机票或类似旅行预订网站时,"js ...总的来说,实现"js text输入框提示火车机票网站点击文本框城市选择"的功能,需要综合运用HTML、CSS和JavaScript,关注用户体验和交互设计,确保在各种设备上都能流畅运行。

    js text文本框弹出城市选择

    在JavaScript(JS)开发中,实现“js text文本框弹出城市选择”的功能是一项常见的交互设计,常见于各种在线服务,比如订机票、酒店预订等网站。这种功能为用户提供了一个友好的界面,允许他们在输入框中点击后弹出...

    Flex文本框自动提示

    Flex文本框自动提示技术是基于Adobe Flex框架的一种用户体验优化功能,它允许用户在输入文本时获得即时的下拉建议或提示。这种功能在各种应用程序中非常常见,如搜索引擎、在线表单和数据输入界面,可以显著提高用户...

    jQuery文本框输入自动提示,类似百度搜索效果

    1. **HTML 结构**:首先,我们需要创建一个文本框和一个用于显示提示结果的下拉列表。HTML 代码如下: ```html 请输入关键词"&gt; ;"&gt; ``` 2. **jQuery 事件绑定**:接下来,我们需要使用 jQuery 的 `keyup` 事件来...

    文本框输入 @ 符号的输入提示的JS代码.rar

    本资源“文本框输入 @ 符号的输入提示的JS代码.rar”聚焦于一个特定的用户界面(UI)功能,即在文本输入框中输入特定字符(如“@”)时显示提示信息。这种功能常见于社交网络或电子邮件服务,当用户输入“@”以提及...

    文本框自动补全,自动提示原来填写过的内容

    通常,文本框会有一个关联的下拉列表或一个浮动的div,用于显示提示内容。 6. **算法和数据结构**:为了快速匹配用户的输入并提供相关建议,需要使用一定的搜索算法,如Trie树、哈希表或者模糊匹配算法。这些算法...

    jquery文本框自动提示

    综上所述,利用jQuery实现文本框自动提示是一项涉及到前端与后端协作的工作,通过监听用户输入、异步请求数据和展示下拉列表,可以显著提升用户的输入体验。在实际项目中,需要根据具体需求进行功能定制和性能优化。

    js文本框输入内容智能提示效果

    JavaScript(简称JS)文本框输入内容智能提示效果是一种常见的用户界面增强技术,它可以在用户在文本框中输入内容时提供实时的建议或匹配项,提高了用户体验。这种效果通常用于搜索框、地址输入、标签添加等场景,...

    jquery给文本框赋上提示功能的插件

    - **插件源码**:实现文本框提示功能的jQuery插件源代码,可能是.js文件,可能包含配置选项和方法。 - **示例HTML**:一个简单的HTML文件,展示了如何在页面中使用该插件。 - **CSS样式**:用于定制插件外观的CSS...

    HTML5实现带提示的精美表单.rar

    在这个登录表单中,当用户点击文本框使其获得焦点时,会显示下拉提示内容。这可以通过CSS3的`:focus`伪类来实现,当输入框被选中时应用特定的样式。同时,可以使用`transition`属性来平滑地改变这些提示内容的显示和...

Global site tag (gtag.js) - Google Analytics