基于jQuery下拉選擇框插件支持單選多選功能代碼
由于最近項(xiàng)目的需求,需要做一個(gè)下拉選擇框的插件,支持單選顯示表單數(shù)據(jù),多選顯示表格數(shù)據(jù),該插件主要運(yùn)用了jQuery與jqgrid以及easyui。
下面給大家展示下效果圖,如果大家感覺還不錯(cuò),請(qǐng)參考實(shí)現(xiàn)代碼:


多選:呈現(xiàn)列表


具體代碼如下所示:
/**
*下拉框插件-chooseList
*調(diào)用插件的方式以及格式:
* 1.首先你需要?jiǎng)?chuàng)建一個(gè)div面板,給div定義ID
* 2.在你所需要的地方調(diào)用插件:
* 參數(shù)說明:
* $("#divID").chooseList({
* query_url :加載下拉框數(shù)據(jù)的URL,指定你所寫編寫的controller地址,如果URL為空則使用插件提供的默認(rèn)URL
* divID:divID
* sidx:排序字段,默認(rèn)罪犯編號(hào)
* sord:排序類型,默認(rèn)desc
* postData: postData: {filters:JSON.stringify(filters)} 自定義查詢條件
* filters的格式如下
* var rules = [];
rules.push({"field":"gydwName","op":"cn","data":"xxxx"});
var filters = {"groupOp":"AND","rules":rules};
isMultiselect:是否多選,默認(rèn)單選false
*
* })
*
*
*/
(function ($) {
$.fn.extend({
chooseList: function (options) {
//產(chǎn)生隨機(jī)數(shù)
var random =Math.floor(Math.random()*100000+1);
/**
* 自定義參數(shù),需要使用其中的屬性直接:customparams.屬性名
*/
var customparams = {
resultObj : {},//存儲(chǔ)單選選擇的后的數(shù)據(jù),返回給外界調(diào)用者使用
resultListObj : new map(),//存儲(chǔ)多選選擇的后的數(shù)據(jù),返回給外界調(diào)用者使用
currentTag : this,//當(dāng)前標(biāo)簽對(duì)象
formID: "form_"+random,
chooseID : "sel"+"_"+random,//下拉選擇框的ID
gridID :"grid"+"_"+random,//dataGrid的ID
pager : "pager"+"_"+random,//分頁ID
countRow :0//計(jì)數(shù)行號(hào),默認(rèn)為0
};
/**
* 參數(shù)和默認(rèn)值
*/
var defaults = {
_search:"false",
//如果未傳入url,則使用默認(rèn)的url進(jìn)行查詢
query_url :contextPath + "/chooseCriminal",
sidx:"bh",//排序字段,默認(rèn)根據(jù)罪犯的編號(hào)bh
sord: "desc",//排序類型:升序,降序 ,默認(rèn)降序
isMultiselect:false,//是否多選,默認(rèn)單選
};
/**
* 裝載默然參數(shù)和傳人的參數(shù)對(duì)象
*/
var options = $.extend(defaults, options);
/**
* 解析載入?yún)?shù)
* @param query_url 請(qǐng)求的地址
* @param flag 標(biāo)識(shí)是第一次加載表格還是模糊查詢加載表格數(shù)據(jù)
*/
var bindParams = function(query_url){
var params="";//存儲(chǔ)解析的參數(shù)
for(var attr in options){
var key = attr;
var value = options[attr];
if(value != "" && !(value instanceof Object)&key!="query_url"&&key!="divID"&&key!=false){
params+=key+"="+value+"&"
}else if(value instanceof Object){
params+=$.param(value)+"&"
}else if(key=="_search"&&value==false){
params+=key+"=false&";
}
}
var finalParams =query_url+"?"+params.substring(0,params.length-1);
return finalParams;
};
/**
* 綁定選擇罪犯combogrid
*/
var renderComboGrid = function(){
$("#"+customparams.chooseID).combogrid({
panelWidth: 500,
idField: 'bh',//id
textField: 'xm',//input顯示值
pagination : true,//是否分頁
pageSize: 10,//每頁顯示的記錄條數(shù),默認(rèn)為10
rownumbers:true,//序號(hào)
url: bindParams(options.query_url),
method: 'get',
fitColumns: true,
columns: [[
{field:'xm',title:'姓名',width:80},
{field:'bh',title:'編號(hào)',width:120},
{field:'gydwName',title:'單位',width:80},
]],
keyHandler:{
query:function(keyword){//動(dòng)態(tài)搜索
var value =keyword;
//裝載動(dòng)態(tài)輸入?yún)?shù)
if(options.postData!=null&&options.postData!=undefined){
var oldRules = JSON.parse(options.postData.filters);
var newRules =[
{"field":"xm","op":"cn","data":value},
(oldRules.rules)[0]
];
var filters = {"groupOp":"AND","rules":newRules};
options = $.extend(defaults, {postData: {filters:JSON.stringify(filters)}});
}else{
var newRules =[
{"field":"xm","op":"cn","data":value}
];
var filters = {"groupOp":"AND","rules":newRules};
options = $.extend(defaults, {queryData: {filters:JSON.stringify(filters)}});
}
//將輸入的值設(shè)置至輸入框中
$("#"+customparams.chooseID).combogrid('setValue', value);
//重新請(qǐng)求后臺(tái)加載表格
$("#"+customparams.chooseID).combogrid("grid").datagrid({url:bindParams(options.query_url)});
}
},
onSelect:function(){//選中事件
var bh= $("#"+customparams.chooseID).combogrid('grid').datagrid('getSelected').bh;//獲取選中行數(shù)據(jù)的編號(hào)
//根據(jù)罪犯編號(hào)獲取罪犯的詳細(xì)信息ajax
$.ajax({
type : 'POST',
url : contextPath + "/chooseList/query",
data :{bh:bh},
success : function(data) {
//填充表單
PlatformUI.populateForm(customparams.formID, data);
//轉(zhuǎn)換對(duì)象中包含時(shí)間類型的數(shù)值
convertDateObject(data);
//判斷當(dāng)前用戶引用的是單選,還是多選
if(options.isMultiselect==false){//單選
$.extend(customparams.resultObj, data);
}else{//多選
addRowData(data);
$.extend(customparams.resultListObj, data);
}
}
});
}
});
};
/**
* 添加表格的行信息
* @param data 數(shù)據(jù)集
*/
var addRowData = function(data){
//判斷當(dāng)前對(duì)象是否已經(jīng)存在resultesObj中,如果存在則不保存,反之則保存
if(!(customparams.resultListObj.containsKey(data.bh))){
customparams.resultListObj.put(data.bh,data);
//獲取行數(shù)據(jù)
var rowData = {xm:data.xm, bh:data.bh, gydwName:data.gydwName};
customparams.countRow = customparams.countRow+1;
//添加行
$("#"+customparams.gridID).addRowData(customparams.countRow, rowData);
var totalRecord = customparams.resultListObj.size();//總條數(shù)
}else{
//提示
toastr.warning("數(shù)據(jù)已被選擇!");
return;
}
};
/**
* 刪除行指定列
* @param bh 編號(hào)
* @param rowId 行ID
*/
var deleteRow = function(bh,rowId){
//刪除集合中的元素
customparams.resultListObj.remove(bh);
//刪除表格中的行
$("#"+customparams.gridID).delRowData(rowId);
//更改行號(hào)
customparams.countRow = customparams.countRow - 1;
};
/**
* 轉(zhuǎn)換對(duì)象時(shí)間戳類型的為yyyy-mm-dd字符串
* @parma data 數(shù)據(jù)
*/
var convertDateObject = function(data) {
if(data.rjrq!=null&&data.rjrq!=undefined){
$("#rjrq").val(DateToString(new Date(data.rjrq)));
}
if(data.csrq!=null&&data.csrq!=undefined){
$("#csrq").val(DateToString(new Date(data.csrq)));
}
if(data.dqxqqr!=null&&data.dqxqqr!=undefined){
$("#dqxqqr").val(DateToString(new Date(data.dqxqqr)));
}
if(data.dqxqzr!=null&&data.dqxqzr!=undefined){
$("#dqxqzr").val(DateToString(new Date(data.dqxqzr)));
}
};
/**
* 日期類型轉(zhuǎn)換成字符串型格式y(tǒng)yyy-MM-dd
* @param DateIn 轉(zhuǎn)換對(duì)象
*
*/
var DateToString = function(DateIn) {
return DateIn.getFullYear()
+ '-'
+ (DateIn.getMonth() + 1 >= 10 ? DateIn
.getMonth() + 1 : '0'
+ (DateIn.getMonth() + 1))
+ '-'
+ (DateIn.getDate() >= 10 ? DateIn.getDate()
: '0' + (DateIn.getDate()));
};
/**
* 自定義map
*/
function map () {
this.elements = new Array();
//得到map的大小
this.size = function() {
return this.elements.length;
}
//判斷是否為空
this.isEmpty = function() {
return (this.elements.length < 1);
}
//清空
this.clear = function() {
this.elements = new Array();
}
//放進(jìn)map一個(gè)對(duì)象
this.put = function(_key, _value) {
this.elements.push( {
key : _key,
value : _value
});
}
//根據(jù)鍵去除一個(gè)對(duì)象
this.remove = function(_key) {
var bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key && typeof this.elements[i].key == typeof _key) {
this.elements.splice(i, 1);
return true;
}
}
} catch (e) {
bln = false;
}
return bln;
}
//根據(jù)鍵得到一個(gè)對(duì)象
this.get = function(_key) {
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key && typeof this.elements[i].key == typeof _key) {
return this.elements[i].value;
}
}
} catch (e) {
return null;
}
}
//返回指定索引的一個(gè)對(duì)象
this.element = function(_index) {
if (_index < 0 || _index >= this.elements.length) {
return null;
}
return this.elements[_index];
}
//是否包含鍵
this.containsKey = function(_key) {
var bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key && typeof this.elements[i].key == typeof _key) {
bln = true;
}
}
} catch (e) {
bln = false;
}
return bln;
}
//是否包含值
this.containsValue = function(_value) {
var bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].value == _value && typeof this.elements[i].value == typeof _value) {
bln = true;
}
}
} catch (e) {
bln = false;
}
return bln;
}
//得到所有的值
this.values = function() {
var arr = new Array();
for (i = 0; i < this.elements.length; i++) {
arr.push(this.elements[i].value);
}
return arr;
}
//得到所有的鍵
this.keys = function() {
var arr = new Array();
for (i = 0; i < this.elements.length; i++) {
arr.push(this.elements[i].key);
}
return arr;
}
};
/**
* 渲染panel視圖
*/
var renderPanelView = function(){
var html = "";
html+="請(qǐng)選擇:<input id='"+customparams.chooseID+"' style='width:200px'/>";
html+="<form id='"+customparams.formID+"'>";
html+="<table>";
html+="<tr>";
html+="<th>姓名:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px ' readonly='true' type='text' id='xm' name='xm' /></td>";
html+="<th>編號(hào):</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true' type='text' id='bh' name='bh' /></td>";
html+="<th>單位:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true' type='text' id='gydwName' name='gydwName' /></td>";
html+="<th>入監(jiān)時(shí)間:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true' type='text' id='rjrq' name='rjrq' /></td>";
html+="<td rowspan='7' style='text-align: center'><img src='' width='140' height='200' alt='' /></td>";
html+="</tr>";
html+="<tr>";
html+="<th>出生日期:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='csrq' name='csrq' /></td>";
html+="<th>身份證號(hào):</th>"
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='sfzh' name='sfzh' /></td>";
html+="<th>原判刑期:</th>"
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='xq' name='xq' /></td>";
html+="<th>當(dāng)前刑期:</th>"
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='dqxq' name='dqxq' /></td>";
html+="</tr>";
html+="<tr>";
html+="<th>刑期起日:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='dqxqqr' name='dqxqqr' /></td>";
html+="<th>刑期止日:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='dqxqzr' name='dqxqzr' /></td>";
html+="<th>處遇等級(jí):</th>";
html+=" <td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='cydjname' name='cydjname' /></td>";
html+="<th>分押類型:</th>"
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='fylxName' name='fylxName' /></td>";
html+="</tr>";
html+="<tr>";
html+="<th>余刑:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='yx' name='yx' /></td>";
html+="<th>軍警經(jīng)歷</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='jjjlName' name='jjjlName' /></td>";
html+="<th>特管類別:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='tglb' name='tglb' /></td>";
html+=" <th>累慣犯:</th>"
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='lgfEnum' name='lgfEnum' /></td>"
html+="</tr>";
html+="<tr>";
html+="<th>是否老犯:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='isSflf' name='isSflf' /></td>";
html+="<th>是否病犯:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='issfbf' name='issfbf' /></td>";
html+="<th>是否殘犯:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='issfcf' name='issfcf' /></td>";
html+="<th>是否危險(xiǎn)犯:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='issfwxf' name='issfwxf' /></td>";
html+="</tr>";
html+="<tr>";
html+=" <th>職務(wù)犯:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='isZwf' name='isZwf' /></td>";
html+="<th>家庭住址:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='familyAddressDetail' name='familyAddressDetail' /></td>";
html+="<th>罪名:</th>";
html+="<td><input style='border-left:0px;border-top:0px;border-right:0px;border-bottom:1px 'readonly='true'type='text' id='accusationId' name='accusationId' /></td>";
html+=" </tr>";
html+=" </table>";
html+="</form>";
$(customparams.currentTag).append(html);
renderComboGrid();
};
/*******************渲染dtaGrid部分*********************/
/**
* 渲染dataGrid表格
*/
var renderGrid = function(){
var gridhtml ="";
gridhtml+="請(qǐng)選擇罪犯:<input id='"+customparams.chooseID+"' style='width:200px'/>";
gridhtml+="<div>";
gridhtml+="<table id='"+customparams.gridID+"'></table> ";
gridhtml+="<div id='"+customparams.pager+"'></div>";
gridhtml+="</div>";
$(customparams.currentTag).append(gridhtml);
renderComboGrid();
initDataGrid();
};
/**
* 加載dataGrid表格數(shù)據(jù)
*/
var initDataGrid =function (){
$("#"+customparams.gridID).jqGrid({
datatype : 'local',
autowidth: true,
height:300,
colNames: ["姓名", "編號(hào)", "單位","操作"],
colModel: [
{ name: "xm", index:"xm",align:"center",width:50,sortable: true},
{ name: "bh", index:"bh", align:"center",width:50, sortable: true},
{ name: "gydwName", index:"gydwName", align:"center",width:50,sortable: true},
{ name: "customColumn",formatter:function(cellvalue, options, rowObject){
var obj = "{bh:" + "\"" + rowObject.bh + "\"" + ",rowId:" + "\"" + options.rowId + "\"" + "}";
var columnTemplate = "<span class='btn_orange innerDelBtn' name='"+ obj +"' >刪除</span>"
return columnTemplate;
}, align:"center",width:50,search:false,sortable: false}
],
sortname: "bh",
sortorder: "desc",
rownumbers:true,//添加左側(cè)行號(hào)
viewrecords: true,
gridview: true,
autoencode: true,
caption: "罪犯信息列表",
gridComplete: function(){
binCompleteEvent();
}
});
};
/**
* 給表格綁定加載完的事件
*/
var binCompleteEvent =function(){
//給操作欄綁定點(diǎn)擊事件
$(".innerDelBtn").click(function(e){
var obj = eval("(" + $(e.target).attr("name") + ")");
deleteRow(obj.bh, obj.rowId);
});
//選中行鼠標(biāo)變?yōu)槭中?
var ids=$("#"+customparams.gridID).jqGrid('getDataIDs');
for(var i = 0; i < ids.length ; i ++){
var id = ids[i];
$("#"+id).attr("style","cursor:pointer");
}
}
/*******************渲染dtaGrid部分結(jié)束*********************/
/**
* 根據(jù)類型渲染視圖
*/
var renderView = function(){
//根據(jù)isMultiselect判斷那種渲染視圖
options.isMultiselect==true?renderGrid():renderPanelView();
};
/***
* 初始化入口
*/
renderView();
//使用三元表達(dá)式判斷返回的應(yīng)是單個(gè)對(duì)象還是多個(gè)對(duì)象
return options.isMultiselect==false?customparams.resultObj:customparams.resultListObj;
}
});
})(jQuery);
以上所述是小編給大家介紹的基于jQuery下拉選擇框插件支持單選多選功能代碼的相關(guān)內(nèi)容,希望對(duì)大家有所幫助!
- Chosen 基于jquery的選擇框插件使用方法
- jQuery實(shí)現(xiàn)選中彈出窗口選擇框內(nèi)容后賦值給文本框的方法
- 基于JQuery的Select選擇框的華麗變身
- 基于jquery實(shí)現(xiàn)select選擇框內(nèi)容左右移動(dòng)添加刪除代碼分享
- jquery通過select列表選擇框?qū)Ρ砀駭?shù)據(jù)進(jìn)行過濾示例
- jquery實(shí)現(xiàn)select選擇框內(nèi)容左右移動(dòng)代碼分享
- 各種選擇框jQuery的選中方法(實(shí)例講解)
- Jquery多選下拉列表插件jquery multiselect功能介紹及使用
- 用jquery實(shí)現(xiàn)下拉菜單效果的代碼
- 用jquery實(shí)現(xiàn)的一個(gè)超級(jí)簡單的下拉菜單
- jQuery模擬12306城市選擇框功能簡單實(shí)現(xiàn)方法示例
相關(guān)文章
EasyUI使用DataGrid實(shí)現(xiàn)動(dòng)態(tài)列數(shù)據(jù)綁定
這篇文章主要介紹了EasyUI使用DataGrid實(shí)現(xiàn)動(dòng)態(tài)列數(shù)據(jù)綁定的相關(guān)資料,需要的朋友可以參考下2022-08-08
Jquery創(chuàng)建層顯示標(biāo)題和內(nèi)容且隨鼠標(biāo)移動(dòng)而移動(dòng)
本文為大家介紹下使用Jquery創(chuàng)建一個(gè)層顯示標(biāo)題的內(nèi)容且隨鼠標(biāo)移動(dòng),具體的實(shí)現(xiàn)如下2014-01-01
基于jquery實(shí)現(xiàn)select選擇框內(nèi)容左右移動(dòng)添加刪除代碼分享
這篇文章主要介紹了基于jquery實(shí)現(xiàn)select選擇框內(nèi)容左右移動(dòng)添加刪除功能,推薦給大家,有需要的小伙伴可以參考下。2015-08-08
jQuery 1.9.1源碼分析系列(十四)之常用jQuery工具
這篇文章主要介紹了jQuery 1.9.1源碼分析系列(十四)之常用jQuery工具的相關(guān)資料,需要的朋友可以參考下2015-12-12
jquery實(shí)現(xiàn)清新實(shí)用的網(wǎng)頁菜單效果
這篇文章主要介紹了jquery實(shí)現(xiàn)清新實(shí)用的網(wǎng)頁菜單效果,涉及jquery通過鼠標(biāo)事件控制頁面元素的動(dòng)態(tài)隱藏與顯示實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08

