input模拟输入下拉框
功能点:
输入、下拉选择、根据输入内容模糊检索、键盘上下键选择
实现思路:
显示隐藏:
input获取焦点显示,失去焦点隐藏
下拉选择:
以父元素为基准,通过绝对定位定位至input输入下方
模糊检索:
监听输入数据的变化,过滤符合要求的数据
键盘上下选择:
监听input的键盘事件,判断keycode值,再触发上下键时,动态计算滚动条滚动的距离
控制事件触发频率,采用函数节流
具体实现过程:
节流函数:
function throttle(func, wait, options) {//函数节流
var context, args, result;
var timeout = null;
var previous = 0;
if (!options) options = {};
var later = function() {
previous = options.leading === false ? 0 : new Date().getTime();
timeout = null;
result = func.apply(context, args);
if (!timeout) context = args = null;
};
return function() {
var now = new Date().getTime();
if (!previous && options.leading === false) previous = now;
var remaining = wait - (now - previous);
context = this;
args = arguments;
if (remaining <= 0 || remaining > wait) {
if (timeout) {
clearTimeout(timeout);
timeout = null;
}
previous = now;
result = func.apply(context, args);
if (!timeout) context = args = null;
} else if (!timeout && options.trailing !== false) {
timeout = setTimeout(later, remaining);
}
return result;
}
}
功能代码:
xxx.directive('inputAndSelect', function ($timeout) {
return {
restrict: 'AE',
replace: true,
require: 'ngModel',
scope: {
'ngModel': '=',
'data': '@',
'callback': '&'
},
template: '<div class="select-box">' +
' <input type="text" ng-focus="inputOnFocus($event)" ng-blur="inputOnBlur()"' +
' ng-model="ngModel" style="z-index: 10;" class="form-control huowu-input"><span class="arrow-down" style="display:inline-block;width: 12px;height: 8px;right: 14px;' +
' border-left: 6px solid transparent;\n' +
' border-right: 6px solid transparent;\n' +
' border-top: 8px solid #818181;"></span>' +
' <div class="select-box-container" style="z-index: 999;background-color: #fff;" ng-show="showSelect">' +
' <div class="select-box-item" ng-click="selectInputItem(item)" ng-repeat="item in dataList">{{item}}</div></div>' +
'</div>',
link: function(scope, element, attrs) {
//显示/隐藏下拉列表
scope.showSelect = false;
scope.dataList = [];
scope.selectIndex = -1;
var eleInput = element.find('input');
eleInput.attr('id', attrs.id);
//input获取焦点
eleInput.unbind('focus').bind('focus',function() {
scope.showSelect = true;
scope.dataList = JSON.parse(scope.data);
element.find('.select-box-container .select-box-item').removeClass('option-active');
$timeout(function () {
element.find('.select-box-container').scrollTop(0);
}, 0);
if (scope.ngModel) {
scope.dataList = scope.dataList.filter(function(vv) {
return vv.indexOf(scope.ngModel) !== -1;
})
}
if(attrs.callback) {
scope.$parent[attrs.callback]();
}
});
//选择输入项
scope.selectInputItem = function(item) {
scope.ngModel = item;
scope.showSelect = false;
};
//input失去焦点
scope.inputOnBlur = function() {
$timeout(function() {
scope.selectIndex = -1;
scope.showSelect = false;
}, 200)
};
//监听输入数据的变化
scope.$watch('ngModel', function(newVal) {
if(!scope.data) return;
var items = JSON.parse(scope.data);
if (!newVal && typeof newVal === 'string') {
scope.dataList = items;
} else {
scope.dataList = items.filter(function(vv) {
return vv.indexOf(newVal) !== -1;
})
}
});
//监听键盘按下事件
eleInput.unbind('keydown').bind('keydown', throttle(function(e) {
//keycode 38 up 40 down
var items = element.find('.select-box-container .select-box-item');
var $container = element.find('.select-box-container');
var keycode = e.keyCode;
if (keycode === 40) {
//按键向下
scope.selectIndex++;
scope.selectIndex = scope.selectIndex > scope.dataList.length - 1 ? 0 : scope.selectIndex;
} else if (keycode === 38) {
//按键向上
scope.selectIndex--;
scope.selectIndex = scope.selectIndex < 0 ? scope.dataList.length - 1 : scope.selectIndex;
} else if (keycode === 13) {
if (scope.selectIndex !== -1) {
scope.ngModel = scope.dataList[scope.selectIndex];
scope.showSelect = false;
}
element.find('input').blur();
}else {
return;
}
items.removeClass('option-active');
$(items[scope.selectIndex]).addClass('option-active');
if(scope.selectIndex === 0) {
$container.scrollTop(0);
}
$container.scrollTop(scope.selectIndex*25);
}, 50));
}
}
})
效果图:

input模拟输入下拉框的更多相关文章
- Chrome浏览器取消INPUT自动记忆下拉框
项目中有一个搜索框,每次聚焦就会出现如下图自动记忆框,遮挡了项目的搜索列表 差了很多资料想要去掉它,最后发现在input上加上autocomplete="off"就可以了!
- 树形下拉框ztree、获取ztree所有父节点,ztree的相关方法
参考:jQuery树形控件zTree使用小结 需求 添加.修改的终端需要选择组织,组织是多级架构(树状图显示). 思路 1.因为下拉框需要树状图显示,所以排除使用select做下拉框,改用input ...
- 用div,ul,input模拟select下拉框
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- struts2 jsp表单提交后保留表单中输入框中的值 下拉框select与input
原文地址:struts2 jsp表单提交后保留表单中输入框中的值 下拉框select与input jsp页面 1 function dosearch() {2 if ($(&q ...
- input+div 下拉选择框
前台html页面 <html> <head> <meta name="viewport" content="width=device-wid ...
- Bootstrap modal模态框关闭时,combobox input下拉框仍然保留在页面上
问题描述: 当点击模态框的关闭按钮时,下拉框中的内容没有消失,而是移动到了页面左上角 分析:这个问题的定位在于是用的哪种模态框,bootstrap和easyui都可以实现模态框,但是两个方法实现的模态 ...
- 使用jquery-combobox实现select下拉框多选之后,如何将下拉框的值传给input隐藏域
我在之前的一篇博文中eaeyui-combobox实现组合查询(即实现多个值得搜索)地址:http://www.cnblogs.com/dushan/p/4778897.html 实现了select下 ...
- 【jQuery获取下拉框select、单选框radio、input普通框的值和checkbox选中的个数】
radio单选框:name属性相同 <input type="radio" id="sp_type" name="p_type" va ...
- jquery.editable-select 可编辑下拉框之获取select值和input值
使用jquery.editable-select可以实现可编辑下拉框的功能,但需要先导入jquery.js,jquery.editable-select.css,jquery.editable-sel ...
随机推荐
- linux安装python3+selenium
安装笔记 当前安装使用centos7 安装python3 1.下载 [admin@ ~] wget https://www.python.org/ftp/python/3.6.0/Python-3.6 ...
- DIY电源拓扑线
记一些小事. 一.材料及工具:电源座DC-005.热熔胶.废弃PCB.锡线.导线.电烙铁.热风枪(或打火机.热熔胶枪) 二.使用热熔胶将电源座粘在一起.两个电源座之间垫一块废弃的PCB,防止两者距离过 ...
- jQuery筛选器常用总结
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- 如何录制Chrome或者Linux下的应用
说明: PortMapping的这种用法其实早就有了,开始我一直没注意到这点,后面才发现了这个功能,特别在<性能测试进阶指南Loadrunner11实战>第二版中更新. 不是所有的对象都能 ...
- C/C++返回内部静态成员的陷阱(转)
在我们用C/C++开发的过程中,总是有一个问题会给我们带来苦恼.这个问题就是函数内和函数外代码需要通过一块内存来交互(比如,函数返回字符串),这个问题困扰和很多开发人员.如果你的内存是在函数内栈上分配 ...
- Android SQLite用法
1.创建SQLite数据库 需要自己创建一个类来继承SQLiteOpenHelper类 SQLiteOpenHelper类是一个创建SQLite数据库的辅助类 继承此类的时候需要重写三个方法 publ ...
- 十图详解tensorflow数据读取机制(附代码)转知乎
十图详解tensorflow数据读取机制(附代码) - 何之源的文章 - 知乎 https://zhuanlan.zhihu.com/p/27238630
- 滴水穿石-07Java开发中常见的错误
1:使用工具Eclipse 1.1 "语法错误" 仅当源级别为 1.5 时已参数化的类型才可用 设置eclipse,窗口—>java—>编译器—>JDK一致性调到 ...
- 微信小程序--WXS---JS 代码插入
主页要使用的JS代码放在index.js里面 例 Page({ data: { array: [1, 2, 3, 4, 5, 1, 2, 3, 4] } }) 只复制以下这段 data: { arra ...
- 转: 解压Assets.car (iOS加密资源)
今天想获取APP的资源,但是查看xxx.app文件夹里面,缺少了大部分资源.在文件夹里面发现Assets.car这个文件,发现文件很大有40多M,猜想图片资源会不会被压缩到这里面了,所以就网络上查了下 ...