前言

扩展自$.fn.combo.defaults和$.fn.datagrid.defaults。使用$.fn.combogrid.defaults重写默认值对象。下载该插件翻译源码

数据表格下拉框结合了可编辑文本框控件和下拉数据表格面板控件,该控件允许用户快速查找和选择,并且该控件提供了键盘导航支持,对行进行筛选

源码

/**
* jQuery EasyUI 1.3.2
*
*翻译:qq 1364386878 下拉表格
*/
(function ($) { function create(jq) {
var options = $.data(jq, "combogrid").options;
var grid = $.data(jq, "combogrid").grid;
$(jq).addClass("combogrid-f");
$(jq).combo(options);
var panel = $(jq).combo("panel");
if (!grid) {
grid = $("<table></table>").appendTo(panel);
$.data(jq, "combogrid").grid = grid;
}
//
grid.datagrid($.extend({}, options, {
border: false,
fit: true,
singleSelect: (!options.multiple),
onLoadSuccess: function (_6) {
var remainText = $.data(jq, "combogrid").remainText;
var remainText = $(jq).combo("getValues");
_setValues(jq, remainText, remainText);
options.onLoadSuccess.apply(jq, arguments);
}, onClickRow: onClickRow,
onSelect: function (rowIndex, rowData) {
retrieveValues();
options.onSelect.call(this, rowIndex, rowData);
},
onUnselect: function (rowIndex, rowData) {
retrieveValues();
options.onUnselect.call(this, rowIndex, rowData);
},
onSelectAll: function (rows) {
retrieveValues();
options.onSelectAll.call(this, rows);
},
onUnselectAll: function (rows) {
if (options.multiple) {
retrieveValues();
}
options.onUnselectAll.call(this, rows);
}
})); function onClickRow(rowIndex, row) {
$.data(jq, "combogrid").remainText = false;
retrieveValues();
if (!options.multiple) {
$(jq).combo("hidePanel");
}
options.onClickRow.call(this, rowIndex, row);
}; function retrieveValues() {
var remainText = $.data(jq, "combogrid").remainText;
var rows = grid.datagrid("getSelections");
var vv = [], ss = [];
for (var i = 0; i < rows.length; i++) {
vv.push(rows[i][options.idField]);
ss.push(rows[i][options.textField]);
}
if (!options.multiple) {
$(jq).combo("setValues", (vv.length ? vv : [""]));
} else {
$(jq).combo("setValues", vv);
}
if (!remainText) {
$(jq).combo("setText", ss.join(options.separator));
}
};
};
//选择行
function selectRow(jq, step) {
var options = $.data(jq, "combogrid").options;
var grid = $.data(jq, "combogrid").grid;
var length = grid.datagrid("getRows").length;
if (!length) {
return;
}
$.data(jq, "combogrid").remainText = false;
var index;
var rows = grid.datagrid("getSelections");
if (rows.length) {
index = grid.datagrid("getRowIndex", rows[rows.length - 1][options.idField]);
index += step;
if (index < 0) {
index = 0;
}
if (index >= length) {
index = length - 1;
}
} else {
if (step > 0) {
index = 0;
} else {
if (step < 0) {
index = length - 1;
} else {
index = -1;
}
}
}
if (index >= 0) {
grid.datagrid("clearSelections");
grid.datagrid("selectRow", index);
}
};
//设置值
function _setValues(jq, values, remainText) {
var options = $.data(jq, "combogrid").options;
var grid = $.data(jq, "combogrid").grid;
var rows = grid.datagrid("getRows");
var ss = [];
for (var i = 0; i < values.length; i++) {
var index = grid.datagrid("getRowIndex", values[i]);
if (index >= 0) {
grid.datagrid("selectRow", index);
ss.push(rows[index][options.textField]);
} else {
ss.push(values[i]);
}
}
if ($(jq).combo("getValues").join(",") == values.join(",")) {
return;
}
$(jq).combo("setValues", values);
if (!remainText) {
$(jq).combo("setText", ss.join(options.separator));
}
};
//查询
function _query(jq, q) {
var options = $.data(jq, "combogrid").options;
var grid = $.data(jq, "combogrid").grid;
$.data(jq, "combogrid").remainText = true;
if (options.multiple && !q) {
_setValues(jq, [], true);
} else {
_setValues(jq, [q], true);
}
if (options.mode == "remote") {
grid.datagrid("clearSelections");
grid.datagrid("load", $.extend({}, options.queryParams, { q: q }));
} else {
if (!q) {
return;
}
var rows = grid.datagrid("getRows");
for (var i = 0; i < rows.length; i++) {
if (options.filter.call(jq, q, rows[i])) {
grid.datagrid("clearSelections");
grid.datagrid("selectRow", i);
return;
}
}
}
};
//实例化组件
$.fn.combogrid = function (target, parm) {
if (typeof target == "string") {
var method = $.fn.combogrid.methods[target];
if (method) {
return method(this, parm);
} else {
return $.fn.combo.methods[target](this, parm);
}
}
target = target || {};
return this.each(function () {
var state = $.data(this, "combogrid");
if (state) {
$.extend(state.options, target);
} else {
state = $.data(this, "combogrid", {
options: $.extend({},
$.fn.combogrid.defaults,
$.fn.combogrid.parseOptions(this),
target)
});
}
create(this);
});
};
//下拉表格默认方法
$.fn.combogrid.methods = {
//返回属性对象
options: function (jq) {
var options = $.data(jq[0], "combogrid").options;
options.originalValue = jq.combo("options").originalValue;
return options;
},
//返回数据表格对象
grid: function (jq) {
return $.data(jq[0], "combogrid").grid;
},
//返回数据表格对象
setValues: function (jq, values) {
return jq.each(function () {
_setValues(this, values);
});
},
//设置组件值
setValue: function (jq, value) {
return jq.each(function () {
_setValues(this, [value]);
});
},
//设置组件值
clear: function (jq) {
return jq.each(function () {
$(this).combogrid("grid").datagrid("clearSelections");
$(this).combo("clear");
});
},
//重置
reset: function (jq) {
return jq.each(function () {
var options = $(this).combogrid("options");
if (options.multiple) {
$(this).combogrid("setValues", options.originalValue);
} else {
$(this).combogrid("setValue", options.originalValue);
}
});
}
};
//解析器
$.fn.combogrid.parseOptions = function (target) {
var t = $(target);
return $.extend({}, $.fn.combo.parseOptions(target),
$.fn.datagrid.parseOptions(target),
$.parser.parseOptions(target, ["idField", "textField", "mode"]));
};
$.fn.combogrid.defaults = $.extend({}, $.fn.combo.defaults,
$.fn.datagrid.defaults, {
loadMsg: null,//在数据表格加载远程数据的时候显示消息
idField: null,//ID字段名称
textField: null,//ID字段名称
//定义在文本改变的时候如何读取数据网格数据。设置为'remote',
//数据表格将从远程服务器加载数据。当设置为'remote'模式的时候,用户输入将会发送到名为'q'的http请求参数,向服务器检索新的数据。
mode: "local", keyHandler: {
up: function () {
selectRow(this, -1);
},
down: function () {
selectRow(this, 1);
},
enter: function () {
selectRow(this, 0);
$(this).combo("hidePanel");
},
query: function (q) {
_query(this, q);
}
},
//定义在'mode'设置为'local'的时候如何选择本地数据,返回true时则选择该行
filter: function (q, row) {
var options = $(this).combogrid("options");
return row[options.textField].indexOf(q) == 0;
}
});
})(jQuery);

示例代码

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ComboGrid Actions - jQuery EasyUI Demo</title>
<link rel="stylesheet" type="text/css" href="../../themes/default/easyui.css">
<link rel="stylesheet" type="text/css" href="../../themes/icon.css">
<link rel="stylesheet" type="text/css" href="../demo.css">
<script type="text/javascript" src="../../jquery-1.8.0.min.js"></script>
<script type="text/javascript" src="../../jquery-1.8.0.min.js"></script>
<script src="../../plugins2/jquery.parser.js"></script>
<script src="../../plugins2/jquery.validatebox.js"></script>
<script src="../../plugins2/jquery.panel.js"></script>
<script src="../../plugins2/jquery.resizable.js"></script>
<script src="../../plugins2/jquery.linkbutton.js"></script>
<script src="../../plugins2/jquery.pagination.js"></script>
<script src="../../plugins2/jquery.combo.js"></script>
<script src="../../plugins2/jquery.datagrid.js"></script>
<script src="../../plugins2/jquery.combogrid.js"></script>
</head>
<body>
<h2>ComboGrid Actions</h2>
<div class="demo-info">
<div class="demo-tip icon-tip"></div>
<div>Click the buttons below to perform actions.</div>
</div>
<div style="margin:10px 0">
<a href="javascript:void(0)" class="easyui-linkbutton" onclick="getValue()">GetValue</a>
<a href="javascript:void(0)" class="easyui-linkbutton" onclick="setValue()">SetValue</a>
<a href="javascript:void(0)" class="easyui-linkbutton" onclick="disable()">Disable</a>
<a href="javascript:void(0)" class="easyui-linkbutton" onclick="enable()">Enable</a>
</div>
<input id="cc" class="easyui-combogrid" style="width:250px" data-options="
panelWidth: 500,
idField: 'itemid',
textField: 'productname',
url: '../combogrid/datagrid_data1.json',
columns: [[
{field:'itemid',title:'Item ID',width:80},
{field:'productname',title:'Product',width:120},
{field:'listprice',title:'List Price',width:80,align:'right'},
{field:'unitcost',title:'Unit Cost',width:80,align:'right'},
{field:'attr1',title:'Attribute',width:200},
{field:'status',title:'Status',width:60,align:'center'}
]],
fitColumns: true
">
<script type="text/javascript">
function getValue(){
var val = $('#cc').combogrid('getValue');
alert(val);
}
function setValue(){
$('#cc').combogrid('setValue', 'EST-13');
}
function disable(){
$('#cc').combogrid('disable');
}
function enable(){
$('#cc').combogrid('enable');
}
</script>
</body>
</html>

插件效果

easyui源码翻译1.32--ComboGrid(数据表格下拉框)的更多相关文章

  1. 第二百二十四节,jQuery EasyUI,ComboGrid(数据表格下拉框)组件

    jQuery EasyUI,ComboGrid(数据表格下拉框)组件 学习要点: 1.加载方式 2.属性列表 3.方法列表 本节课重点了解 EasyUI 中 ComboGrid(数据表格下拉框)组件的 ...

  2. ComboGrid( 数据表格下拉框)

    一. 加载方式//class 加载方式<select id="box" class="easyui-combogrid" name="dept& ...

  3. easyui源码翻译1.32+API翻译全篇导航 (提供下载源码)

    前言 EasyUI每个组件都会有 属性.方法.事件 属性 所有的属性都定义在jQuery.fn.{plugin}.defaults里面.例如,对话框属性定义在jQuery.fn.dialog.defa ...

  4. easyui源码翻译1.32--PropertyGrid(属性表格)

    前言 继承自$.fn.datagrid.defaults.使用$.fn.propertygrid.defaults重写默认值对象.下载该插件翻译源码 属性表格提供The propertygrid pr ...

  5. easyui源码翻译1.32--TreeGrid(树形表格)

    前言 扩展自$.fn.datagrid.defaults.使用$.fn.treegrid.defaults重写默认值对象.下载该插件翻译源码 树形表格用于显示分层数据表格.它是基于数据表格.组合树控件 ...

  6. ExtJs 扩展类CheckColumn修改源码,支持按条件禁用启用下拉框功能

    长话短说,具体的请看图 需求如图: 修改CheckColumn.js源码,添加鼠标点击改变事件 完整JS脚本 Ext.ns('Ext.ux.grid'); Ext.ux.grid.CheckColum ...

  7. jQuery EasyUI/TopJUI创建树形表格下拉框

    jQuery EasyUI/TopJUI创建树形表格下拉框 第一种方法(纯HTML创建) <div class="topjui-row"> <div class= ...

  8. easyui源码翻译1.32--datagrid(数据表格)

    前言 此前网上有easyui1.25的源码  应该算是比较老的版本  之后又经历了1.26 . 1.3. 1.31. 1.32 .1.33.1.34  1.33开始支持css3 算是又一个转折  但是 ...

  9. easyui源码翻译1.32--Combo(自定义下拉框)

    前言 扩展自$.fn.validatebox.defaults.使用$.fn.combo.defaults重写默认值对象.下载该插件翻译源码 自定义下拉框显示一个可编辑的文本框和下拉面板在html页面 ...

随机推荐

  1. 一个Notification 进度条插件(android,NJS实现,直接就可使用)

    参考文章:http://ask.dcloud.net.cn/article/503 源码地址下载 如题,分享一个Notification 进度条插件(android,用js调用原生api实现,直接就可 ...

  2. 认识JSON

    JSON 全称 JavaScript Object Notation,意思是JavaScript对象表示法.是一种基于文本的.独立于语言的轻量级数据交换格式.易于阅读和编写,易于机器解析和生成. 一. ...

  3. .bak文件在英文版的sqlserver2014如何生成和恢复

    生成bak备份文件 1.选择数据库 2.右击选择task 3.选择backup 4.

  4. 我的MFC学习之路(一)

    因为项目需求,我开始应用MFC写程序.具体接触MFC的时间大概也有两个月了.现在的水平算是刚刚踏入了MFC大门的半只脚.目前能基本使用MFC Class Wizard,可以根据实例仿照完成需求,小范围 ...

  5. kettle Argument, Parameter, Variable

    1. Argument, Parameter, Variable 的区别 a.Argument作为位置参数不能复用,而其他2个可以根据名称重复使用 b. Argument, Parameter作用域局 ...

  6. vs2010开发android的准备工作

    安装 Mono for Android for Visual Studio 2010 需要下面4个步骤: 安装 JDK 安装 Android SDK 配置模拟器 安装 Mono for Android ...

  7. Cisco交换机中的flash,Rom,RAM,nvram的区别

    Flash内存,也叫闪存,是路由器当中常用的一种内存类型.它是可读写的存储器,在系统重新启动或关机之后仍能保存数据.Flash中存放着当前使用中的IOS(路由器操作系统). 只读内存(ROM)在Cis ...

  8. navagationController 的子控制器如何取消右滑返回

    1.首先在navagationController的某个控制器中 遵守:UIGestureRecognizerDelegate 2.在viewDidload中设置: self.navigationCo ...

  9. Ajax的概述与实现过程

    一.ajax概述 1.Ajax是Asynchronous([ə'sɪŋkrənəs) JavaScript XML的简写,不是一门新技术,而是对现有技术的综合利用.这一技术能够向服务器请求额外数据而无 ...

  10. 写入.csv文件

    #include "stdafx.h" #include "WriteCsv.h" CString m_strData;//写入记录的一条数据 CString ...