zoukankan      html  css  js  c++  java
  • easyui combobox的增加全选解决方案

        1、解决方案背景:

      项目中偶然需要用到easyui的combobox的组件,但是本组件自己没有包含全选的api事件。搜索了一些解决方案,但是不是很符合,后来发现是因为所使用的版本不一致所导致的。项目中使用的1.5的版本,而网上大部分的解决方案都是采用的自定义onSelect的方案,自己动手试过,确实不能,因为1.5版本的组件,在自定义onSelect的函数触发后,选择 了全部的值赋值给当前的组件,在赋值的同时,又会自动的触发onSelect的事件,会不断的陷入死循环中去。后来自己决定重新实现解决方案,重新定义onClick的事件,此事件是在1.5版本之后才有效使用的,下面介绍实现的具体方案。

         2、实际解决方案:

         自己封装AllCheckCombobox.js.源代码如下所示:

    /**
     *自己扩展easyui的 combobox,使其能够有全选和反选的功能。
     **/
    var AllCheckCombobox = (function (mod,selectId){
    	
    		var select = $("#"+selectId);
    		/*
    		 * combobox获取data的函数,可以替换成动态后台ajax获取,此处只是静态数据模拟。
    		 */
    		var getData = function (){
    			var data =[{"text":"长沙","value":"111"},{"text":"常德","value":"222"}];
    			data.unshift({"text":"全选/反选","value":""});
    			return data;
    		};
    		
    		/*
    		 * 扩展的核心函数之一,自己扩展combobox的onclick的函数,判断是否是全选/反选 选项,
    		 *  若果是 则选中全部的选项,否则,清空全部的选项
    		 */
    		var onclick = function (record){
    			var valueField = select.combobox("options").valueField;
    			if(!record[valueField]){
    				var data = select.combobox("getData");
    				var values = select.combobox("getValues");
    				var selectVaues = [];
    				if((data.length - 1) != values.length){
    					data.reduce(function(prev, current, index, array){
    						selectVaues.push(current[valueField]);
    					},selectVaues);
    				}else{
    					selectVaues.push(record[valueField]);
    				}
    				select.combobox('setValues', selectVaues); 
    			}
    		};
    	
    		/*
    		 * combobox的初始化函数,还可以自己设定一些其他的选项,可以参看easyui的官网。
    		 */
    		mod.initCombobox = function (){
    			$('#'+selectId).combobox({
    				valueField : 'value',
    				textField : 'text',
    				multiple : true,
    				editable : false,
    				panelHeight : 'auto',
    				panelMaxHeight : 300,
    				data : getData(),
    				onClick:onclick,
    				label : "城市 :",
    				labelPosition : "before",
    				labelAlign : 'right'
    			});
    		};
    	return mod;
    })(window.AllCheckCombobox || {},'select');
    

      具体的项目中的data 可以冲后台ajax获取,在动态获取到data数据后,自动的在最前面给增加一个"全选"的选项,扩展的onclick的事件,也是对当前的选择的值进行判断,得出的结果,来进行对当前的下拉框赋值操作。

        3、测试代码:

    <!DOCTYPE html>
    <html>
    <head>
     <meta http-equiv="X-UA-Compatible" content="IE=edge" />
     <meta charset="UTF-8">
     <title>测试页面</title>
     <link rel="stylesheet" type="text/css"	href="easyui/themes/gray/easyui.css">
     <link rel="stylesheet" type="text/css"	href="easyui/themes/icon.css">
    </head>
    <body>
    	<div id="panel" style="98%;padding:10px 10px;">
    		<input id="select" style="20%;" value=""/>
    	</div>
    </body>
    <script type="text/javascript" src="easyui/jquery.min.js"></script>
    <script type="text/javascript" src="easyui/jquery.easyui.min.js"></script>
    <script type="text/javascript" src="easyui/locale/easyui-lang-zh_CN.js"></script>
    <script type="text/javascript" src="AllCheckCombobox.js"></script>
    <script type="text/javascript">
     	$(function(){
    		AllCheckCombobox.initCombobox();
    	});
    </script>
    </html>
    

       4、测试效果:

    选择全选的选项,就会自动的选择下面的所有的值,获取当前选中的值,可以使用easyui的combobox的getValues获取。

     

  • 相关阅读:
    3.21上午
    3.17下午
    2017.4.14-morning
    2017.4.13-afternoon
    2017.4.13-morning
    2017.4.12-afternoon
    2017.4.12-morning
    2017.4.11-afternoon
    2017.4.11-morning
    2017.4.10-afternoon
  • 原文地址:https://www.cnblogs.com/lilin0719/p/6822283.html
Copyright © 2011-2022 走看看