chosen.jquery.js 搜索框只能从头匹配的解决思路+方法
chosen.jquery.js 搜索框只能从头匹配的解决思路+方法
心急者请直接看下方 总结 ,由于本问题未能找到直接答案,所以只能通过修改源码解决。故将修改源码思路贴出来供大家参考,在遇到其他改源码问题时应如何思考。
chosen.jquery.js(地址:http://harvesthq.github.io/chosen)是一款非常优秀的表单select框美化插件。它提供了一些非常实用的功能。但是在实用中却又有一些问题。
搜索从头匹配问题
首先,我们初始化一个chosen实例:
html:
 <select data-placeholder="选择省份..." class="chosen-select" style="width:350px;" tabindex="2">
   <option value="">请选择省份</option>
   <option value="110000" hassubinfo="true">北京</option>
   <option value="120000" hassubinfo="true">天津</option>
   <option value="130000" hassubinfo="true">河北省</option>
   ...
</select>- 1
- 2
- 3
- 4
- 5
- 6
- 7
js:
<script type="text/javascript">
    $(function(){
        $(".chosen-select").chosen();
    })
</script>- 1
- 2
- 3
- 4
- 5
初始化完成后效果如图:
在输入框填入关键词搜索:
可以发现关键词只能从头匹配,因此只搜索出 北京,河北省却未被搜索出。
解决
可以想到上述问题应该是正则匹配的问题,只需找到搜索时的匹配正则并修改,便可以达到我们想要的目的。
通过审查元素可以看到:
插件实例化时有插件内置class:active-result. 
所以,打开chosen.jquery.js源码,查找 active-result. 
可以发现这个方法,result_add_option,显然是将数据填入新生成的插件select弹出框中的方法。 
继续搜索 result_add_option,看看哪里调用了这个方法发现:
明显是生成option对象的方法。
继续搜索,看看在哪里调用:
发现这个方法。在本方法内,可以发现
这便是搜索匹配语句。
console.log(regex);
发现它是从头匹配的正则:
发现源码中挨着regex便定义了正则zregex:
而zregex 便是我们需要的正则。故将插件源码340行 regex 替换成 zregex即可达到目的。
总结
故将插件源码340行 regex 替换成 zregex。或搜索regex定位到如下一行:
将regex 替换成 zregex。 效果:
TO
JavaScript jquery-chosen 选择框插件
Chosen 是一个JavaScript插件,它能让丑陋的、很长的select选择框变的更好看、更方便,不仅如此,它更扩大了,增长了主动筛选的功能。它可对列表进行分组,同时也可禁用某些选择项。目前,它支持 jQuery 和 Prototype 两种JavaScript引擎。
http://harvesthq.github.com/chosen/
<select class="chzn-select" data-placeholder="Choose a Country" style="width:350px;" tabindex="1">
               <option value=""></option>
               <option value="United States">United States</option>
               <option value="United Kingdom">United Kingdom</option>
               <option value="Afghanistan">Afghanistan</option>
               <option value="Albania">Albania</option>
</select>
初始化:
$(".chzn-select").chosen();
 
js参数设置
在调用chosen()办法时,我们可以设置一些参数:
选项 描述 no_results_text 无搜刮成果显示的文本 allow_single_de 是否容许作废选择 max_ed_options 当为多选时,最多选择个数
搜不到时,提示:
 $(".chzn-select").chosen({
                                      no_results_text: "没有找到",
                                      allow_single_de: true
});
事务
a) change事务:
$(".chzn-select").chosen().change(function(){
   ......
});
b) 当我们须要动态更新下的选择项时,只要在更新选择项后触发Chosen中的liszt:d事务就可以了:
$(".chzn-select").html(""...<%option%>china<%/option%>..."");
$(".chzn-select").trigger("liszt:d");
若是不想要搜刮框的话,用css把它隐蔽掉:
.chzn-container-single .chzn-search {
    display: none;
}
提示下:
ie6和ie7直接返回对象本身,看chosen.jquery.js:
if ($.browser.msie && ($.browser.version === "6.0" || ($.browser.version === "7.0" && document.documentMode === 7))) {
        return this;
}
chosen.jquery.js 使用笔记
chosen.jquery.js 使用笔记
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | using chosen.jquery.jsusing chosen.jquery.csshtml:<labelfor="MeetingUsersList" class="label"><strongclass="fg-red">∗</strong> 参会人员</label><selectdata-placeholder="请选择参会人员..." id="MeetingUsersList" multiple="multiple" class="chosen-select form-control"></select><inputtype="hidden" id="MeetingUsers" placeholder="参会人员" name="MeetingUsers"><inputtype="hidden" id="MeetingUsersName" placeholder="参会人员" name="MeetingUsersName"><divclass="field-validation-error" data-valmsg-for="MeetingUsersList"  validata="MeetingUsers"></div> j s:        $.ajax({            type: "post",            url: "/UserMeeting/MeetingUserList",//初始化下拉多选列表            global: false,            success: function (data) {                $('#MeetingUsersList').html(data);//绑定下拉值                //初始化                var chose = $("#MeetingUsersList").chosen({                    no_results_text: "Sorry,未检索到相关数据!",                    max_selected_options: 100,                    width: "100%"                });                var aa = 1;                chose.trigger("liszt:updated");                chose.change(function (e, t) {                    var selectedTitle = '';                    var selected = '';                    $("div[validata='MeetingUsers']").css('display', 'none');                    selected = $("#MeetingUsersList").val();                    $.each($(".chosen-container .search-choice"), function (i, e) {                        selectedTitle += $(e).find('span').text() + ',';                    });                    $("#MeetingUsers").val(selected);//保存选择值                    $("#MeetingUsersName").val(selectedTitle.substring(0, selectedTitle.length - 1));//保存选择标题                    chose.trigger('chosen:updated');                }).bind("chosen:maxselected", function () {                    $("div[validata='MeetingUsers']").css('display', 'block').html('请选择参会人员!');                    return false;                });                //初始化设置值                chose.val($("#MeetingUsers").val().split(','));//根据value设置选中值,设置的时候如果多个 传数组                chose.trigger('chosen:updated');//传递完成之后刷新            }        }); | 
 chosen.jquery.js 搜索框只能从头匹配的解决思路+方法的更多相关文章
- JQuery限制文本框只能输入数字和小数点的方法
		<input type="text" class="txt NumText" Width="100px" /> $(func ... 
- chosen.jquery.js
		http://baifjece.blog.163.com/blog/static/33794654201286102519119/ ------------------首次加载设置默认选中项----- ... 
- 用jQuery实现搜索框的过滤效果
		遇到的问题: 1.动态添加了某些元素,在动态添加的某个元素上绑定事件失效 原因:因为需要绑定的元素的直接父元素也是动态添加的解决:向上为上一级父元素绑定事件 $(".check-box&qu ... 
- jQuery实现搜索框插件+豆瓣音乐接口实现豆瓣搜索框
		jQuery实现搜索框插件 豆瓣音乐接口实现豆瓣搜索框 豆瓣接口有时不稳定,网络请求会报400,不要惊慌.我主要是练习一下jQuery的JSONP和封装插件. <div class=" ... 
- 用Jquery控制文本框只能输入数字和字母
		用Jquery控制文本框只能输入数字和字母 $.fn.onlyNum = function () { $(this).keypress(function (event) { var eventObj ... 
- JQuery 限制文本框只能输入数字和小数点
		$(function(){ /*JQuery 限制文本框只能输入数字*/ $(".NumText").keyup(function(){ $(this).val($(this).v ... 
- chosen.jquery.js 使用笔记
		using chosen.jquery.js using chosen.jquery.css html: <label for="MeetingUsersList" clas ... 
- 使用pycharm搜索框和正则表达式匹配内容
		使用pycharm搜索框和正则表达式匹配内容原创薯饼__ 最后发布于2019-03-04 19:28:53 阅读数 660 收藏展开有时候我们要在爬虫网站中匹配各种各样的文本块,以获取需要的信息,每一 ... 
- Jquery实现搜索框提示功能
		博客的前某一篇文章中http://www.cnblogs.com/hEnius/p/2013-07-01.html写过一个用Ajax来实现一个文本框输入的提示功能.最近在一个管理项目的项目中,使用后发 ... 
随机推荐
- No-7.运算符
			数学符号表链接:https://zh.wikipedia.org/wiki/数学符号表 01. 算数运算符 是完成基本的算术运算使用的符号,用来处理四则运算 运算符 描述 实例 + 加 10 + 20 ... 
- JAVA基础——设计模式之装饰者模式
			装饰模式 : 对新房进行装修并没有改变房屋的本质,但它可以让房子变得更漂亮.更温馨.更实用. 在软件设计中,对已有对象(新房)的功能进行扩展(装修). 把通用功能封装在装饰器中,用到的地方 ... 
- C++链表STL
			#include <iostream> #include <list> #include <algorithm> #include <stdlib.h> ... 
- IDEA打war包部署本地TOMCAT测试
			在Eclipse中打war包很方便,导出即可直接选择war包,如下图所示: 但是在IDEA中有点麻烦,网上很多教程,做的也都很好,我自己也做一份,加深一下印象. 首先打开File->Projec ... 
- Centos下PHP7.1打开Oracle扩展
			背景 最近因为项目研究了一下PHP集成Oracle,虽然这个组合很奇葩,但万一用到请勿采坑~ 环境 CentOS Linux release 7.3.1611 (Core) PHP7.1.1 安装or ... 
- SQL-Redis使用详细教程
			一.Redis基础部分: 1.redis介绍与安装比mysql快10倍以上 *****************redis适用场合**************** 1.取最新N个数据的操作 2.排行榜应 ... 
- 一个IT工薪族的4年奋斗成果
			关于标题:为了方便传播,使用了"最简化"的一段. 过段时间,考虑改为"大学毕业4年-回顾和总结(11):一个IT工薪族的4年奋斗成果(2012年6月17日~2016年6 ... 
- 九度oj 题目1516:调整数组顺序使奇数位于偶数前面
			题目1516:调整数组顺序使奇数位于偶数前面 时间限制:1 秒 内存限制:128 兆 特殊判题:否 提交:3416 解决:1091 题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序, ... 
- 测试各种低价VPS
			1) dream.jp 540多的日元一个VPS,是全日本最低的VPS,但是用了以后发现最大问题是受限很多,不好用,如果你打算用作建ss或者其它***功能,对不起,请找其它VPS了 在日本dream. ... 
- LA3263 一笔画
			题目大意:依次给定多个点(要求第一个点和最后一个点重叠),把前后两个点相连求最后得到的图形的面的个数 根据欧拉定理: 设平面图的顶点数为V,边数为E,面数为F,则V+F-E = 2 这里的E是指如果一 ... 
