表单/表格

多项选择下拉列表框组件

阿里云


jquery.multiselect.js 是一款基于 jQuery UI 的多项选择下拉列表框组件。该下拉列表功能强大,可以实现多选和单选,可制作打开和关闭下拉框时的炫酷动画效果,提供丰富的回调函数和其它方法。

使用方法

使用该多选下拉列表框插件需要在页面中引入 jQuery UI 相关文件,jQuery 以及插件本身需要的 jquery.multiselect.css 和 jquery.multiselect.js 文件。

也想出现在这里?联系我们
创客主机
  1. <link rel="stylesheet" type="text/css" href="css/jquery.multiselect.css" />
  2. <link rel="stylesheet" type="text/css" href="http://libs.useso.com/js/jqueryui/1.10.4/css/jquery-ui.min.css" />
  3. <script type="text/javascript" src="src/jquery.min.js"></script>
  4. <script type="text/javascript" src="http://libs.useso.com/js/jqueryui/1.10.4/jquery-ui.min.js"></script>
  5. <script type="text/javascript" src="src/jquery.multiselect.js"></script>

HTML 结构

该下拉列表框的 HTML 结构为标准的下拉列表框结构,同时需要为它添加 multiple 属性。

  1. <select id="example" name="example" multiple="multiple">
  2.   <option value="1">Option 1</option>
  3.   <option value="2">Option 2</option>
  4.   <option value="3">Option 3</option>
  5.   <option value="4">Option 4</option>
  6.   <option value="5">Option 5</option>
  7. </select>

初始化插件

在页面 DOM 元素加载完毕之后,可以通过 multiselect()方法来初始化该下拉列表框插件。

  1. $(document).ready(function(){
  2.    $("#example").multiselect();
  3. });

配置参数

可以在初始化插件的时候以对象的方式传入需要的参数:

  1. $("select").multiselect({
  2.    header: "请选择一个选项!"
  3. });
参数 默认值 描述
header true 是否显示下拉列表框的头部,如果传入的是一个字符串,默认的"check all", "uncheck all" 和 "close"超链接将被字符串替换
height 175 checkbox 容器区域(滚动区域)的高度,如果设置为“auto”,会自动根据选项的多少来进行计算
minWidth 225 整个组件的最小宽度,设置为“auto”将禁用该属性
checkAllText Check all 默认的“Check all”文本
uncheckAllText Uncheck All 默认的“Uncheck All”文本
noneSelectedText Select options 选项被选择时 select box 的默认文本
selectedText # selected 选项被选择时显示在 select box 中的文本(如果selectedList设置为 false)。#会被自动替换为被选择的选项的序号。如果使用 2 个#,那么第二个会被看做是可选选项的总数,例如# of # checked。该选项还可以接收一个带 3 个参数的匿名函数:被选择选项的序号,可用选项的总数和被选择的 checkbox 的 DOM 元素
selectedList false 被选择选项的列表,如果设置为 false 表示禁用该功能。
show 空字符串 下拉列表打开时的动画效果,要控制动画的速度,可以传入一个数组:['slide', 500]
hide 空字符串 下拉列表关闭时的动画效果,要控制动画的速度,可以传入一个数组:['slide', 500]
autoOpen false 下拉列表是否在初始化后自动展开
multiple true 如果设置为 false,组件将使用单选按钮代替多选按钮,此时只可以进行单选
classes 空字符串 自定义的 class 类。可以通过它对选项进行分隔。你需要自定义按钮和下拉列表的 CSS 样式:
/* button */ .ui-multiselect.myClass {}
/* menu */ .ui-multiselect-menu.myClass {}
position 空对象 该选项可以将下拉菜单放置在相对于下拉按钮的任何地方:entered, above, below(默认)等。

事件

该下拉列表框调用方法的方式如下:

  1. // 绑定事件
  2. $("#multiselect").bind("multiselectopen", function(event, ui){
  3.     // 事件处理
  4. });
  5.  
  6. // 在初始化时传入事件处理函数
  7. $("#multiselect").multiselect({
  8.     open: function(event, ui){
  9.         // 事件处理
  10.     }
  11. });

事件参数

事件 描述
create 组件第一次被创建时触发
beforeopen 下拉菜单被打开前触发,返回 false 可以阻止下拉菜单的打开
open 下拉菜单被打开后触发
beforeclose 下拉菜单被关闭前触发,返回 false 可以阻止下拉菜单的关闭
close 下拉菜单被关闭后触发
checkall 所有选项被选择或点击头部的“全部选择”按钮时触发
uncheckall 所有选项都不被选择或点击头部的“全部不选择”按钮时触发
optgrouptoggle optgroup标签被点击时触发。该事件接收原始事件对象作为参数
click 当 checkbox 被选择或取消选择时触发

方法

当插件被初始化为一个实例之后,可以通过方法名称来调用方法。

  1. $("#multiselect").multiselect("method_name");
方法 描述
open 打开下拉菜单
close 关闭下拉菜单
refresh 重新加载下拉列表。如果你通过 Ajax 或操作 DOM 元素的方法来动态的添加和删除了列表选项,可以通过refresh方法来刷新列表
disable 禁用下拉列表
enable 启用下拉列表
checkAll 全部选择
uncheckAll 全部不选
isOpen 返回代表当前下拉列表是否打开的布尔值
getChecked 返回当前被选择的选项的数组
getButton 返回按钮元素
widget 返回下拉列表容器元素
option 在插件初始化之后设置或获取一个选项。如果修改了选项,它会立刻生效
destroy 销毁实例

Github 地址:https://github.com/ehynds/jquery-ui-multiselect-widget

多项选择下拉列表框组件

已有 601 人购买
查看演示升级 VIP立刻购买

演示地址 下载地址
收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!