query多选下拉框插件 jquery-multiselect

query function callback jquery documentation input

目录(?)[+]

  1. 特性
  2. 兼容性
  3. 用法
    1. 回调函数
    2. 重载项
    3. Passing a function to the selectedText parameter
  4. 参数

效果:http://www.erichynds.com/examples/jquery-ui-multiselect-widget/demos/

特性

  • 支持点击label实现checkbox组选择.
  • 头部选项,如全选/ 取消全选 /关闭功能.
  • 支持键盘选择.
  • 支持5种不同的事件回调函数.
  • 以列表方式显示选中项目,并且可以设置最大显示值.
  • 方便改变位置,渐变速度,滚动容器的高度,链接文字,文本框默认内容等.
  • 最小版只有 6.9kb.

兼容性

  • Firefox 2 – 3.6
  • IE 6 – 8
  • Chrome Beta/4
  • Safari 4
  • Opera 10

用法

首先需要引入 jquery 1.4、jQuery UI theme, 和 jquery.multiselect.css . 我们在这用的不是jQuery UI library本身,而是他的主题文件. 最简单的绑定select box方法:

Html代码
  1. <select id="MySelectBox" multiple="multiple" name="MySelectBox"> <option value="1">Option 1option> <option value="2">Option 2option>select> 
[html] view plain copy print ?
  1. <select id="MySelectBox" multiple="multiple" name="MySelectBox"> <option value="1">Option 1option> <option value="2">Option 2option>select> 

 

Js代码
  1. $(document).ready(function(){  
  2.     $("#MySelectBox").multiSelect();  
  3. }); 
[js] view plain copy print ?
  1. $(document).ready(function(){ 
  2.     $("#MySelectBox").multiSelect(); 
  3. }); 

 

回调函数

比如其中的 onOpen 回调函数, 如:

Js代码
  1. $("#MySelectBox").multiSelect({  
  2.     onOpen: function(){  
  3.         var $checkboxes = $(this).find('input');  
  4.     }  
  5. }); 
[js] view plain copy print ?
  1. $("#MySelectBox").multiSelect({ 
  2.     onOpen: function(){ 
  3.         var $checkboxes = $(this).find('input'); 
  4.     } 
  5. }); 

 

onClick 回调函数. Example:

Js代码
  1. $("#MySelectBox").multiSelect({  
  2.     onClick: function(){  
  3.         if(this.checked){  
  4.             alert("I was just checked!");  
  5.         }  
  6.     }  
  7. }); 
[js] view plain copy print ?
  1. $("#MySelectBox").multiSelect({ 
  2.     onClick: function(){ 
  3.         if(this.checked){ 
  4.             alert("I was just checked!"); 
  5.         } 
  6.     } 
  7. }); 

 

更多回调函数请看下面列表.

重载项

参数选项均在 $.fn.multiSelect.defaults中保存 , 你可以如下改变默认选项:

Js代码
  1. // set the minWidth parameter for all instances to 500 pixels  
  2. .fn.multiSelect.defaults.minWidth = 500; 
[js] view plain copy print ?
  1. // set the minWidth parameter for all instances to 500 pixels 
  2. .fn.multiSelect.defaults.minWidth = 500; 

 

Passing a function to the selectedText parameter

As of 0.5, the selectedText parameter can accept an anonymous function with three arguments: the number of checkboxes checked, the total number of checkboxes, and an array of the checked checkbox DOM elements. As you can see in the example, this gives you 100% control of the display:

Js代码
  1. $("#MySelectBox").multiSelect({  
  2.     selectedText: function(numChecked, numTotal, checkedInputs){  
  3.  
  4.         // example: emulating the default behavior  
  5.         return numChecked + " checked";   
  6.  
  7.         // example: emulating the selectedList option  
  8.         return (numChecked < = 5)  
  9.             ? checkedInputs.map(function(element){ return element.title; }).join(', ')  
  10.             : numChecked + " checked";  
  11.     }  
  12. }); 
[js] view plain copy print ?
  1. $("#MySelectBox").multiSelect({ 
  2.     selectedText: function(numChecked, numTotal, checkedInputs){ 
  3.  
  4.         // example: emulating the default behavior 
  5.         return numChecked + " checked";  
  6.  
  7.         // example: emulating the selectedList option 
  8.         return (numChecked < = 5) 
  9.             ? checkedInputs.map(function(element){ return element.title; }).join(', '
  10.             : numChecked + " checked"
  11.     } 
  12. }); 
[js] view plain copy print ?
  1. "t6">参数

     

参数

Parameter Description Default
showHeader A boolean value denoting whether or not to display the header containing the check all, uncheck all, and close links. true
maxHeight The maximum height in pixels of the scrolling container that holds the checkboxes. 175
minWidth The minimum width in pixels of widget. Setting to auto (default) will inherit the width from the original select element. 200
checkAllText The default text of the “Check all” link. Check all
unCheckAllText The default text of the “Uncheck all” link. Uncheck all
noneSelectedText
Renamed from noneSelected in 0.5!

The default text the select box when no options have been selected.

Select options
selectedList A boolean/numeric value denoting whether or not to display the checked opens in a list, and how many. A number greater than 0 denotes the maximum number of list items to display before switching over to the selectedText parameter. A value of 0 or false is disabled. false
selectedText The text to display in the select box when options are selected (if selectedList is false). The pound sign (#) is automatically replaced by the number of checkboxes selected. If two pound signs are present in this parameter, the second will be replaced by the total number of checkboxes available. Example: “# of # checked”.
New in 0.5!

As of 0.5, this parameter can also accept an anonymous function with three arguments: the number of checkboxes checked, the total number of checkboxes, and an array of the checked checkbox DOM elements. See the examples.

# selected
position The position of the options menu relative to the input control: top, middle, or bottom. bottom
shadow A boolean value denoting whether to apply a css shadow (class ui-multiselect-shadow). false
fadeSpeed How fast (in ms) to fade out the options menu on close. 200
state
New in 0.5!

The default state of the widget. Either open or closed.

closed
disabled
New in 0.5!

Whether or not to disabled the widget by default. Important: see the “Known Issues” section below for more documentation on this.

false
onCheck A callback to fire when a checkbox is checked. Function
onOpen A callback to fire when the options menu is opened. Function
onCheckAll A callback to fire when the “Check all” link is clicked. Function
onUncheckAll A callback to fire when the “Uncheck all” link is clicked. Function
onOptgroupToggle A callback to fire when the opgroup header is clicked. An array of checkboxes inside the optgroup is passed as an optional argument.

你可能感兴趣的:(js)