jQuery+css模拟下拉框模糊搜索的实现
html:
@*输入框*@
<div>
<input type="text" style="width: 85%; height: 34px;" onkeyup="InputChange(this)" id="txtInput">
</div>
@*模拟下拉框*@
<div class="divselect" id="dpSelect"> </div>
css:
/*选择框效果*/
.divselect {
float: left;
position: relative;
z-index:;
background: #fff;
display: none;
width: 85%;
}
.divselect ul {
padding:;
margin:;
border: 1px solid #E4E4E4;
background-color: #ffffff;
position: absolute;
z-index:;
margin-top: -1px;
width: 100%;
overflow: auto;
max-height: 200px;
}
.divselect ul li {
list-style-type: none;
cursor: pointer;
height: 24px;
line-height: 24px;
}
.divselect ul li:hover {
background: #ccc;
}
js:
<script type="text/javascript">
//点击模拟下拉框以外的地方 下拉框消失
$(document).bind('click', function (e) {
var e = e || window.event; //浏览器兼容性
var elem = e.target || e.srcElement;
while (elem) { //循环判断至跟节点,防止点击的是div子元素
if (elem.id && elem.id == 'dpSelect') {
return;
}
elem = elem.parentNode;
}
$('#dpSelect').css('display', 'none'); //点击的不是div或其子元素
}); //用文本框onkeyup事件触发InputChange方法 InputChange方法判断文本框文字是否改变 文字改变则触发SearchName方法
var sOldValue;
sOldValue = "";
function InputChange(arg) {
var vNewValue = $(arg).val();
if (sOldValue != vNewValue) {
//根据条件查询结果并给下拉框动态赋值
SearchName(arg);
sOldValue = vNewValue;
}
}
function SearchName(arg) {
var name = $(arg).val();
//如果搜索框为空 则返回false
if (name == "") {
$("#dpSelect").attr("style", "display:none");
return false;
}
else {
$("#dpSelect").attr("style", "display:block");
}
//获取数据 并给下拉框动态赋html
$.ajax({
type: "post",
url: "......",
data: { name: name },
dataType: "",
async: false,
success: function (data) {
var strs = "";
strs += "<ul>";
for (var i = 0; i < data.length; i++) {
strs += '<li onclick="SetValue(this)">' + data[i] + '</li>';
}
strs += "</ul>";
$("#dpSelect").html(strs);
},
error: function () {
alert("查询出错");
}
}); }
//点击模拟下拉框内选项后 给文本框赋值 关闭下拉框
function SetValue(arg) {
var value = $(arg).text();
$("#txtInput").val(value);
$("#dpSelect").attr("style", "display:none");
}
</script>
jQuery+css模拟下拉框模糊搜索的实现的更多相关文章
- jquery模拟下拉框单选框复选Select,Checkbox,Radio
在项目中,你会发现设计稿中常常会有单选框,复选框,但都不是系统默认的样式,这就可以用jquery来模拟它们:如图所示,实现它们所需要的代码如下: 首先需要引入的代码: <link rel=&qu ...
- 项目总结12:bootstrap-select下拉框模糊搜索
bootstrap select下拉框模糊搜索 关键字 bootstrap-select 下拉框模糊搜索 正文(直接上源码) <%@ page language="java" ...
- JS模拟下拉框select
最近做的一个项目有下拉框 同事都是用的是美化控件,但是用美化控件当然是好 但是网上找的一个控件不知道扩展性怎么样?对以后的维护会不会造成有影响?比如我想增加一个功能或者减少一个功能会不会影响?还有就是 ...
- jQuery之双下拉框
双下拉框要实现的效果,实际上就是左边下拉选择框里的内容,可以添加到右边,而右边同理.写了个简单的例子,来说明一下. 代码如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...
- div模拟下拉框
1.模拟下拉框.点击文本框在文本框下面显示一个层divList,点击divList以外的任何地方,关闭divList层 document.body.onclick = function (e) { e ...
- jquery操作select下拉框的各种方法,获取选中项的值或文本,根据指定的值或文本选中select的option项等
简介jquery里对select进行各种操作的方法,如联动.取值.根据值或文本来选中指定的select下拉框指定的option选项,读取select选中项的值和文本等. 这一章,站长总结一下jquer ...
- jQuery操作select下拉框的text值和value值的方法
1.jquery获取当前选中select的text值 $("#select1").find("option:selected").text(); 2.jquer ...
- js&jquery 获取select下拉框的值、文本内容、自定义属性
js&jquery 获取select下拉框的值.文本内容.自定义属性 CreationTime--2018年7月2日09点22分 Author:Marydon html <selec ...
- JQuery操作select下拉框
JQuery操作select下拉框 获取Select选择的Text和Value $("#select_id").change(function(){//code...}); //为 ...
随机推荐
- Could not find a valid gem 'rails' (>= 0), here is why
很长一段时间之前 Ruby Rails入门--windows下搭建Ruby Rails Web开发环境 ,由于后来将Ruby的安装文件从 C 盘移动到了 D 盘,也修改了 Path 环境变量,ruby ...
- 解决PKIX问题:unable to find valid certification path to requested target
第一步:执行方式:java InstallCert hostname eg:java InstallCert www.cebbank.com 第二步:然后输 ...
- Kivy: Building GUI and Mobile apps with Python
Intro Python library for building gui apps (think qt, gdk,processing) build from ground up for lates ...
- 快排的python实现
快排的python实现 #python 2.7 def quick_sort(L): if len(L) <= 1: return L else: return quick_sort([lt f ...
- 【解题报告】[动态规划]-PID69 / 过河卒
原题地址:http://www.rqnoj.cn/problem/69 解题思路: 用DP[i][j]表示到达(i,j)点的路径数,则 DP[0][0]=1 DP[i][j]=DP[i-1][j]+D ...
- Kafka源码深度解析-序列7 -Consumer -coordinator协议与heartbeat实现原理
转自:http://blog.csdn.net/chunlongyu/article/details/52791874 单线程的consumer 在前面我们讲过,KafkaProducer是线程安全的 ...
- Oracle记录(四) 简单查询、限定查询、数据的排序
一.简单查询 SQL(Structured Query Language) 结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理关系数据库系统.ANSI(美国国家标准学会) ...
- Ubuntu14.04安装Matlab2014a
尝试在Ubuntu14.04下安装matlab2014a已经有两天了,即便是照着csdn上的步骤进行安装依然出现了不少问题,究其原因是对linux下的命令不理解,下面就自己摸索结合博客内容总结一下安装 ...
- Google Cloud VM上在线扩硬盘
Google Cloud VM是可以在线扩展Disk的大小的. 一.创建VM和磁盘 比如我有一台VM,附加了一块Disk,大小是120GB.如下图: 在VM中进行格式化: mkfs.ext4 -F / ...
- strtotime出现时区问题不一致的解决方法
学习源头:https://blog.csdn.net/longjuanfengzc/article/details/80622842 https://segmentfault.com/q/101000 ...