<!DOCTYPE HTML>
<html>
<head>
<title> New Document </title>
<meta name="Generator" content="EditPlus">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
<!--
(function ($) {
$.fn.zMultiSelect = function (zSetting, zData) {
//默认设置
var defaultVal = {
json : true,//是否通过json对象导入选项
hasHidden : false,//是否需要隐藏域
hiddenName : "",//隐藏域的name的值
hasAllChecked : true,//是否需要添加全选选项
textSeparator : ";",//文本框中的连接符
valueSeparator : ";"//隐藏域中的连接符
};
//将用户设置与默认设置合并
var setting = $.extend(true,{}, defaultVal, zSetting);
//遍历jquery对象,并返回该jquery对象
return this.each(function () {
var $this = $(this);//当前dom封装成jquery对象
var objId = $this.attr("id");//当前对象的id,也可用this.id来获取
var spanId = objId+"_span";//添加_span后缀做为悬浮框的id
//为当前对象绑定单击事件,先隐藏所有悬浮框,然后显示当前对象关联的悬浮框,并阻断事件继续传播
$this.bind('click',function(e){
$("span[id$=_span]").hide();
$("#"+spanId).show();
e.stopPropagation();//阻断事件传播
});
if(setting.json){
//如果设置json为true,则按设置载入数据,对象前后添加隐藏域和悬浮框
loadJson($this,setting,zData);
}
//为当前对象关联的多选框添加单击事件
$("[class=" + objId + "]:checkbox").bind("click",function(e){
//如果为全选复选框,则相应全选,全不选,相关选项
if(this.value==""){
if(this.checked){
$("[class=" + objId + "]:checkbox").attr("checked", true);
}else {
$("[class=" + objId + "]:checkbox").attr("checked", false);
}
}
//将已选项的值连接起来赋值给文本框和隐藏域
onchangeCheckState($this,setting);
});
//阻止span及其子元素的单击事件传播到document
$("#"+spanId).bind('click',function(e){
e.stopPropagation();//阻断事件传播
});
//单击document时,隐藏所有悬浮框
$(document).bind('click',function(){
$("span[id$=_span]").hide();
});
})
};
//添加悬浮框及隐藏域
function loadJson(obj,setting,zData){
var hasHidden = setting.hasHidden;
var objId = obj.attr("id");
var spanId = objId+"_span";
//--------------------拼接悬浮框span-----------------------------------------------------------
var spanAdd = '<span id="'+spanId+'">';
if(setting.hasAllChecked){
//添加全选选项
spanAdd += '<div cellpadding="0" cellspacing="0" style="width:100%;border-style: none none solid none;border-color:gray;border-width:1px;"><input type="checkbox" id="'+objId + '_all' +'" class="'+objId+'" value=""/>';
spanAdd += '<label for="' + objId + '_all' + '">全选</label></div>';
}
for(var item in zData){
//多选框id,有隐藏域时,为文本框id+_+json对象的属性名,没有隐藏域时,为文本框id+_+json对象的属性值
var checkboxId = (hasHidden) ? (objId + '_' + item) : (objId + '_' + zData[item]);
//多选框的value,根据hasHidden设置为属性名或属性值
var checkboxValue = (hasHidden) ? item : zData[item];
//添加各选项
spanAdd += '<input type="checkbox" id="'+checkboxId+'" class="'+objId+'" value="'+checkboxValue+'"/>';
spanAdd += '<label for="'+checkboxId+'">'+zData[item]+'</label><br>';
}
spanAdd += '</span>';
//--------------------拼接span结束-----------------------------------------------------------
//添加悬浮框
obj.after($(spanAdd));
//为悬浮框添加class设置样式,并隐藏,同时添加mouseover和mouseout事件
$("#"+spanId).addClass("spanFloater").hide().hover(
function(){ $(this).show(); },
function(){ $(this).hide(); }
);
//添加隐藏域
if(hasHidden){
var hiddenId = objId+"_value";//添加_value后缀做为隐藏域的id
var hiddenAdd = '<input type="hidden" id="'+hiddenId+'" name="'+setting.hiddenName+'">';
obj.before($(hiddenAdd));
}
};
//单击复选框事件,为文本框和隐藏域赋值
function onchangeCheckState(obj,setting){
var objId = obj.attr("id");
var hiddenId = objId+"_value";
var kArr = new Array();
var vArr = new Array();
//获取已选项的值,赋值给数组
$("input[class=" + objId + "][value!='']:checked").each(function (index) {
kArr[index] = this.value;
vArr[index] = $(this).next().text();
});
//串联数组,赋值给文本框和隐藏域
if(setting.hasHidden){
$("#"+hiddenId).val(kArr.join(setting.valueSeparator));
}
obj.val(vArr.join(setting.textSeparator));
}
})(jQuery);
$(document).ready(function () {
var setting = {json:true,hasHidden:true,hiddenName:"dict_dim_Level",textSeparator:",",valueSeparator:"-"}
var data = {nanjing:"南京",shanghai:"上海",yangzhou:"扬州",suzhou:"苏州",wuxi:"无锡",changzhou:"常州",yancheng:"盐城",xuzhou:"徐州",taizhou:"泰州",huaian:"淮安"};
$("input").zMultiSelect(setting,data).attr("readonly","readonly");
});
//-->
</script>
<style type="text/css">
.spanFloater{display:block;width:inherit;position: absolute; z-index:10;background:#F0F6E4;border: 1px solid #617775;}
#dim_Level {width:150px}
#dim_Level+span {width:155px}
#dim_Level2 {width:150px}
#dim_Level2+span {width:155px;background:lightgreen;border: 1px solid #617775;font-family: 方正舒体;font-size:25px;}
</style>
</head>
<body>
<table>
<tr>
<td>已覆盖城市:</td>
<td><div><input type="text" id="dim_Level"></div></td>
<td>欲拓展城市:</td>
<td><div><input type="text" id="dim_Level2"></div></td>
</tr>
</table>
</body>
</html>

第一次写jquery插件,有很多粗陋的地方,希望路过的朋友能够指点一二

注:easy ui 中已经有了这样的下拉多选框

我的第一个jquery插件:下拉多选框的更多相关文章

  1. 使用jQuery为文本框、单选框、多选框、下拉框、下拉多选框设值及返回值的处理

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

  2. 品优购商城项目(二)AngularJS、自动代码生成器、select2下拉多选框

    品优购商城想项目第二阶段 AngularJS.自动代码生成器.select2下拉多选框 完成了课程第三天.第四天的的任务. 1.学习了AngularJs前端的mvc分层思想,js部分分成control ...

  3. angular2.x 下拉多选框选择组件

    angular2.x - 5.x 的下拉多选框选择组件 ng2 -- ng5.最近在学angular4,经常在交流群看见很多人问 下拉多选怎么做... 今天就随便写的个. 组件源码 百度云   链接: ...

  4. 自己用ul模拟实现下拉多选框,

    模拟实现下拉多选框 效果如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  5. 自定义实现 PyQt5 下拉复选框 ComboCheckBox

    一.前言 由于最近的项目需要具有复选功能,但过多的复选框会影响界面布局和美观,因而想到把 PyQt5 的下拉列表和复选框结合起来,但在 PyQt5 中并没有这样的组件供我们使用,所以想要自己实现一个下 ...

  6. jquery--获取多选框的值、获取下拉多选框的值

    获取多选框的值 var packageCodeList=new Array(); $('#server_id:checked').each(function(){ packageCodeList.pu ...

  7. jQuery插件——下拉选择框

    其实,之前也写过jQuery插件,今天写的是一个模拟select选择的下拉插件. 既然是jQuery插件,那么必然是依赖jQuery的了. 老规矩,直接上代码吧! ;(function () { $. ...

  8. ios一个自定义的下拉多选菜单

    前段时间项目刚好要做到条件筛选菜单,正好找到一些别人写的,结合自己实际需求进行优化修改,一个实用的多条件筛选菜单,根据其他的下拉进行一些改进. 点击后返回点击文字显示 github地址:https:/ ...

  9. selectpicker下拉多选框ajax异步或者提前赋值=》默认值

    Bootstrap select多选下拉框赋值 success: function (data) { var oldnumber = new Array(); $.each(data, functio ...

随机推荐

  1. RethinkDB

    RethinkDB最早是作为一个对SSD进行专门优化的MySQL存储引擎出现的,其特点在于对SSD的充分利用.而目前RethinkDB已经脱离MySQL成为一个独立的存储. RethinkDB目前支持 ...

  2. mysql卸载

    先执行mysql安装程序,点击移除,然后再删除对应的安装路径,必要的时候还要删除注册表信息.

  3. Week1 Team Homework #3: 软件工程在北航

    在组内成员的共同努力,我们采访了几个学长学姐,顺利完成任务.反馈信息如下: 平均每周花在这门课上的时间 平均写的代码总行数 学到的最有用的部分 最没用的部分 <软件工程>最应该改进的地方 ...

  4. SCRUM报告(一)

    我们“来用”团队确定的PM是邓锐.这是我们第一篇SCRUM报告,报告的内容就是我们的Sprint会议.之前冲刺计划会议的内容已发博客,这里简单阐述一下. 一.会议过程大致如下: 1.总结目前的工作进展 ...

  5. iOS开发 适配iOS10以及Xcode8-b

    现在在苹果的官网上,我们已经可以下载到Xcode8的GM版本了,加上9.14日凌晨,苹果就要正式推出iOS10系统的推送了,在此之际,iOS10的适配已经迫在眉睫啦,不知道Xcode8 beat版本, ...

  6. Zabbix实现告警分级

    Zabbix中trigger的severity的值定义了trigger的不同严重程度,其中severity默认的6个值为 Not classified, Information, Warning, A ...

  7. 01-08-01【Nhibernate (版本3.3.1.4000) 出入江湖】NHibernate中的三种状态

    以下属于不明来源资料: 引入 在程序运行过程中使用对象的方式对数据库进行操作,这必然会产生一系列的持久化类的实例对象.这些对象可能是刚刚创建并准备存储的,也可能是从数据库中查询的,为了区分这些对象,根 ...

  8. crud springmvc

    实体类:Student.java package demo.entity; public class Student { private int id; private String name; pr ...

  9. Unity3D研究院之IOS全自动打包生成ipa

    接着上一篇文章, 自动生成framework,这篇文章我把shell自动化打包ipa整理了一下,希望大家喜欢,嘿嘿.. 建议大家先看一下上一篇文章.http://www.xuanyusong.com/ ...

  10. hdoj 1875 畅通工程再续

    题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1875 //9403289 2013-10-24 17:00:49 Accepted 1875 62M ...