JQ模糊查询插件
//构造函数写法
;(function($,window,document,undefined){//注意这里的分号必须加
//插件的全部代码
var FazzSearch = function (ele, options) {
// if(options =='undefinded' || options == Object )
this.$element = ele,
this.defaults = {
//这里的this是JQuery对象
triggerID: this.$element.attr("id"),
fazzArr : [],
searchArr: [],
// methods: methods,
listWidth: '100%',
$this: ele,//提示当前对象的dom节点名称,这里的this关键字都指向一个不同的DOM元素(每次都是一个不同的匹配元素)。
listDom: null,
selector: this.$element.attr("id")+'_item',
isPos: false,
isNeedBlurSetTime: false,
itemCallback: function () { },
callback: function () { },
},
this.opts = $.extend({}, this.defaults, options);
}
FazzSearch.prototype = {
//初始化
init : function(){
var _this = this;
return this.$element.each(function(){ //遍历匹配的元素及插件实例的所有元素,此处的this表示为jquery对象,而不是dom对象
$(this).css({ })
$(this).bind('input propertychange', function() {
_this.initData();
});
if(this.isNeedBlurSetTime){
$(this).on('blur',function(e){
var self = $(this);
var setT = setTimeout(function(){
self.siblings('.fazzSearchList').html('').hide();
console.log('失交');
clearTimeout(setT)
},300)
})
}
})
},
initData : function(){
this.opts.listDom = this.opts.listDom ? this.opts.listDom : this.$element.next('.fazzSearchList');//如果出现兄弟节点有两个
this.opts.fazzArr = [];
this.initListDomStyle();
this.adEventInputChange();
},
initListDomStyle : function(){
var listDom = this.opts.listDom;
listDom.html('');
listDom.css({'width':this.$element.outerWidth()},{'padding':'10px 0 10px 6px'});
if(("ontouchstart" in window)){
listDom.css('width',this.$element.parent().outerWidth());
if(listDom.hasClass('liPc')){
listDom.removeClass('liPc');
}
listDom.addClass('liMoblie');
}else{
if(listDom.hasClass('liMoblie')){
listDom.removeClass('liMoblie')
}
listDom.addClass('liPc');
}
console.log(this.$element)
if(this.opts.isPos){
listDom.parent().css('position','relative');
listDom.addClass('liPcPosi');
listDom.css('top',this.$element.outerHeight())
}
},
//添加子节点
addChild : function(item,selector){
return "<li class='" + selector + "' data-val='" + item + "'>"+item+"</li>";
},
//如果输入值为空,清除缓存和数组dom
closeData : function(){
this.opts.fazzArr = [];
this.opts.listDom.html('').hide();
},
//监听input输入框值改变
adEventInputChange : function(){
var fazzSearchValue = this.$element.val();//input输入框值改变
console.log('fazzSearchValue->',fazzSearchValue)
if(fazzSearchValue==''){
this.closeData();
return;
}
this.dealWithData(fazzSearchValue);
},
//处理子节点绑定点击事件
listItemBindClick : function(){
$('body').on('click',opts.selector,function(){ })
},
//如果存在模糊数组
hasData : function(item){
var listDom = this.opts.listDom;
listDom.show();
listDom.append(this.addChild(item));
this.opts.fazzArr.push(item);
},
//处理模糊数组匹配和子节点添加
dealWithData : function(fazzSearchValue){
var searchArr = this.opts.searchArr;
for (var i = 0; i < searchArr.length; i++) {
var result = searchArr[i].indexOf(fazzSearchValue);
if( result > -1 && this.opts.fazzArr.indexOf(searchArr[i])== -1){
this.hasData(searchArr[i]);
}
}
} }
//在插件中使用Beautifier对象
$.fn.fazzSearch = function(options){
//创建Beautifier的实体
//this为jQuery选中的元素集合
var fazzSearch = new FazzSearch(this,options);
//调用其beautify方法
return fazzSearch.init();
//以后在此处调用新的方法即可,格式为:
//return beautifier.方法名()
}
})(jQuery,window,document);
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
<link rel="stylesheet" type="text/css" href="./css/fazzSearchBox.css"/>
<style type="text/css">
*{margin: 0;padding: 0;}
</style>
<script src="js/jquery-1.8.3.min.js" type="text/javascript" charset="utf-8"></script>
<script src="js/fazzExtend.js" type="text/javascript" charset="utf-8"></script>
</head>
<body>
<input type="text" name="" id="fazzSearch" value="" class="fazzSearch"/>
<ul class="fazzSearchList fazzSearchList1"></ul> <input type="text" name="" id="fazzSearch1" value="" class="fazzSearch"/>
<ul class="fazzSearchList fazzSearchList2"></ul>
<script type="text/javascript">
// var arr=[{ id:1,val:"sss"},{ id:2,val:"bb"},{ id:11,val:"advvasc"},{ id:3,val:"a"},{ id:4,val:"c"},{ id:5,val:"d"},{ id:6,val:"x"},{ id:7,val:"5"},{ id:8,val:"4"}]
$(function(){
var arr = ['333','1111','aaa','bbb','c','b','z'];
$('#fazzSearch').fazzSearch({
searchArr:arr,
listDom: $('.fazzSearchList1'),
isPos:true
})
$('#fazzSearch1').fazzSearch({
searchArr: arr,
listDom: $('.fazzSearchList2'),
})
});
</script>
</body>
</html>
.fazzSearch{outline: none;border: 1px solid #ccc;width: 80px;height: 40px;line-height: 40px;text-indent: 5px;}
.fazzSearchList{display: block;display: none;width: 100%;max-height: 120px;overflow-y: auto;border: 1px solid #F6F7F8;background-color: #ffffff;}
.fazzSearchList li{cursor: pointer;height: 30px;line-height: 30px;width: 97%;text-align: left;color: #222;border-bottom: 1px solid #CCCCCC;white-space: nowrap;text-overflow: ellipsis;overflow: hidden; word-break: break-all;}
.fazzSearchNoData{padding: 0;color: red;}
.liPcPosi{position: absolute;top: 0;left: 0;}
.liPc li {color: #999;border-bottom: 1px solid #f1f1f1;}
.liPc li:last-child{border-bottom: 0;}
.liMoblie li {color: #999;border-bottom: 1px solid #f1f1f1;}
.liMoblie li:last-child{border-bottom: 0;}
.special{position: absolute;top: 0;left: 0;z-index: 100;}
JQ模糊查询插件的更多相关文章
- K3 WISE 开发插件《SQL语句WHERE查询-范围查询/模糊查询》
0.存储过程开头变量定义 @FBeginDate varchar(10), --单据起始日期 @FEndDate varchar(10), --单据截止日期. @FItemID varchar(50) ...
- 十三、K3 WISE 开发插件《SQL语句WHERE查询-范围查询/模糊查询》
0.存储过程开头变量定义 ), --单据起始日期 ), --单据截止日期. ), ), ), ), ) @FType varchar(50), --单据类型@FBillNo varchar(50), ...
- js前端实现模糊查询
对于模糊查询,一般都是传关键字给后端,由后端来做.但是有时候一些轻量级的列表前端来做可以减少ajax请求,在一定程度上提高用户体验.废话不多说,直接上代码. //字符串方法indexOfvar len ...
- 编写简易的JS输入框模糊查询匹配(附有源码和demo)
前言:JS输入框模糊匹配插件以前在工作写过一个类似的 所以这次写轻松很多,这次写优化了几个方面: 1. 添加动态加载css文件 不需要引入css css全部在JS动态生成. 2. 不需要额外的标签 只 ...
- Bootstrap-table学习笔记(二)——前后端分页模糊查询
在使用过程中,一边看文档一边做,遇到了一些困难的地方,在此记录一下,顺便做个总结: 1,前端分页 2,后端分页 3,模糊查询 前端分页相当简单,在我添加了2w条测试数据的时候打开的很流畅,没有卡顿. ...
- 表单模糊查询的三种简单方式(springboot-h2-mybatis)
前几天运营提到说后台管理系统有几个地方想要模糊查询.. 想了下是简单的,就是要注意以前方法的被调用情况,进行增量改动,以免牵一发而动全身.整理一波记录下(本次案例是按名字模糊查询学生信息). 三种 ...
- js的模糊查询
在项目中会用到模糊查询,之前在首页是用的element的tree显示的目录,会有用到搜索,但tree里边会有自带的模糊查询,用filter-node-method方法使用 但上次的项目中 又涉及到不试 ...
- MyBatis Plus之like模糊查询中包含有特殊字符(_、\、%)
传统的解决思路:自定义一个拦截器,当有模糊查询时,模糊查询的关键字中包含有上述特殊字符时,在该特殊字符前添加\进行转义处理. 新的解决思路:将like 替换为 MySQL内置函数locate函数 参考 ...
- select2 智能补全模糊查询select2的下拉选择框使用
我们在上篇文章中已经在SpringMVC基础框架的基础上应用了BootStrap的后台框架,在此基础上记录select2的使用. 应用bootstrap模板 基础项目源码下载地址为: SpringMV ...
- MyBatis Plus 实现多表分页模糊查询
项目中使用springboot+mybatis-plus来实现. 但是之前处理的时候都是一个功能,比如分页查询,条件查询,模糊查询. 这次将这个几个功能合起来就有点头疼,写下这边博客来记录自己碰到的问 ...
随机推荐
- M-SOLUTIONS Programming Contest 2020 游记 (AB水题,CD模拟,E题DFS)
A - Kyu in AtCoder 水题 B - Magic 2 题意很好理解,但写的时候注意一下边界 void solve() { int a, b, c, k; cin >> a & ...
- liunx上升级python2至python3
一.背景介绍 虚拟机的liunx系统CentOS7自带了python2.7.5,为使用方便需要换成最新的版本3.10.4 二.安装方法 1.安装升级GCC yum install -y gcc* op ...
- jmap 查看jvm内存大小并进行dump文件内存分析
本文为博主原创,未经允许不得转载: 1.jmap的使用 Jmap 可以用来查看内存信息,实例个数以及占用内存大小. jmap -histo[:live] 打印每个class的实例数目,内存占用,类全名 ...
- wireshark 抓包使用
本文为博主原创,转载请注明出处: 在项目开发过程当中,尤其在联调和测试功能的使用,经常会用到抓包,用抓包进行问题的定位. 所以记录一下wireshark的使用,如何抓包,分析,保存等. wiresha ...
- 文件传输中的MD5校验技术
1. 文件的MD5校验简介 文件的MD5校验是一种常用的文件完整性验证方法.MD5(Message Digest Algorithm 5)是一种广泛应用的哈希算法,它能够将任意长度的数据转换为固定长度 ...
- java - 创建文件
package practice; import java.io.File; import java.io.IOException; public class CreateFile { public ...
- ffmpeg 字幕解码
原文: https://blog.csdn.net/u011283226/article/details/102241233 [写在前面] 在前一篇,我已经讲过了读取外挂字幕并显示的方法:理解过滤图并 ...
- GoMusic-歌单迁移工具网站 一键迁移网易云/QQ音乐歌单至 Apple/Youtube/Spotify Music
GoMusic是什么: GoMusic是一个在线歌单迁移工具网站,帮助用户一键迁移网易云/QQ音乐歌单至 Apple/Youtube/Spotify Music,直接输入歌单链接,复制查询结果,打开 ...
- blender 3D 汽车模型下载
前言 因为之前需要模拟摄像头拍摄汽车车牌,从各种途径下载了一些blender 3D 汽车模型,现将模型分享出来,如有需要,直接去最后面下载地址下载即可 目前已经车型40多款 车型图 70年代Porsc ...
- 如何让你的.NET WebAPI程序支持HTTP3?
下面我将总结构建Http3的经验,以Token Gateway的项目为例,请注意使用Http3之前你需要知道它的限制, Windows Windows 11 版本 22000 或更高版本/Window ...