lovCombo
来源:互联网 发布:真人语音朗读软件 编辑:程序博客网 时间:2024/05/13 14:47
// add RegExp.escape if it has not been already added
if ('function' !== typeof RegExp.escape) {
RegExp.escape = function(s) {
if ('string' !== typeof s) {
return s;
}
// Note: if pasting from forum, precede ]// with backslash manually
return s.replace(/([.*+?^=!:${}()|[/]////])/g, '//$1');
}; // eo function escape
}
// create namespace
Ext.ns('Ext.ux.form');
/**
*
* @class Ext.ux.form.LovCombo
* @extends Ext.form.ComboBox
*/
Ext.ux.form.LovCombo = Ext.extend(Ext.form.ComboBox, {
// {{{
// configuration options
/**
* @cfg {String} selectAllOn the value of the option used as
* the select-all / deselect-all trigger
*/
selectAllOn: null,
/**
* @cfg {String} checkField name of field used to store checked state.
* It is automatically added to existing fields.
* Change it only if it collides with your normal field.
*/
checkField: 'checked'
/**
* @cfg {String} separator separator to use between values and texts for getValue and submission
*/
, separator: ','
/**
* @cfg {String} displaySeparator displaySeparator to use between values and texts for display
*/
, displaySeparator: ','
/**
* @cfg {String/Array} tpl Template for items.
* Change it only if you know what you are doing.
*/
// }}}
// {{{
, initComponent: function() {
// template with checkbox
if (!this.tpl) {
this.tpl =
'<tpl for=".">'
+ '<div class="x-combo-list-item">'
+ '<img src="' + Ext.BLANK_IMAGE_URL + '" mce_src="' + Ext.BLANK_IMAGE_URL + '" '
+ 'class="ux-lovcombo-icon ux-lovcombo-icon-'
//+'{[values.' + this.checkField + '?"checked":values.' + this.checkField + '===null?"mixed":"unchecked"' + ']}">'
+ '{[values.' + this.checkField + '?"checked":"unchecked"' + ']}">'
+ '<div class="ux-lovcombo-item-text">{' + (this.displayField || 'text') + '}</div>'
+ '</div>'
+ '</tpl>'
;
}
// call parent
Ext.ux.form.LovCombo.superclass.initComponent.apply(this, arguments);
// install internal event handlers
this.on({
scope: this
, beforequery: this.onBeforeQuery
//,blur:this.onRealBlur
});
// remove selection from input field
this.onLoad = this.onLoad.createSequence(function() {
if (this.el) {
var v = this.el.dom.value;
this.el.dom.value = '';
this.el.dom.value = v;
}
});
} // e/o function initComponent
// }}}
// {{{
/**
* Disables default tab key bahavior
* @private
*/
, initEvents: function() {
Ext.ux.form.LovCombo.superclass.initEvents.apply(this, arguments);
// disable default tab handling - does no good
this.keyNav.tab = false;
} // eo function initEvents
// }}}
// {{{
/**
* clears value
*/
, clearValue: function() {
this.value = '';
this.setRawValue(this.value);
this.store.clearFilter();
this.store.each(function(r) {
r.set(this.checkField, false);
}, this);
if (this.hiddenField) {
this.hiddenField.value = '';
}
this.applyEmptyText();
} // eo function clearValue
// }}}
// {{{
/**
* @return {String} separator (plus space) separated list of selected displayFields
* @private
*/
, getCheckedDisplay: function() {
var re = new RegExp(RegExp.escape(this.separator), "g");
return this.getCheckedValue(this.displayField).replace(re, RegExp.escape(this.displaySeparator) + ' ');
} // eo function getCheckedDisplay
// }}}
// {{{
/**
* @return {String} separator separated list of selected valueFields
* @private
*/
, getCheckedValue: function(field) {
field = field || this.valueField;
var c = [];
// store may be filtered so get all records
var snapshot = this.store.snapshot || this.store.data;
snapshot.each(function(r) {
if (r.get(this.checkField) && r.data[this.valueField] !== this.selectAllOn)
c.push(r.get(field));
}, this);
return c.join(this.separator);
} // eo function getCheckedValue
, selectAllCheck: function() {
var snapshot = this.store.snapshot || this.store.data;
var selectAll = true;
snapshot.each(function(r) {
if (r.data[this.valueField] !== this.selectAllOn && !r.get(this.checkField)) {
selectAll = false;
return;
}
}, this);
return selectAll;
}
// }}}
// {{{
/**
* beforequery event handler - handles multiple selections
* @param {Object} qe query event
* @private
*/
, onBeforeQuery: function(qe) {
qe.query = qe.query.replace(new RegExp(this.getCheckedDisplay() + '[ ' + RegExp.escape(this.separator) + ']*'), '');
} // eo function onBeforeQuery
// }}}
// {{{
/**
* blur event handler - runs only when real blur event is fired
*/
, beforeBlur: function() {
this.list.hide();
var rv = this.getRawValue();
var rva = rv.split(new RegExp(RegExp.escape(this.displaySeparator) + ' *'));
var va = [];
var snapshot = this.store.snapshot || this.store.data;
// iterate through raw values and records and check/uncheck items
Ext.each(rva, function(v) {
snapshot.each(function(r) {
if (v === r.get(this.displayField)) {
va.push(r.get(this.valueField));
}
}, this);
}, this);
this.setValue(va.join(this.separator));
this.store.clearFilter();
} // eo function onRealBlur
// }}}
// {{{
/**
* Combo's onSelect override
* @private
* @param {Ext.data.Record} record record that has been selected in the list
* @param {Number} index index of selected (clicked) record
*/
, onSelect: function(record, index) {
if (this.fireEvent('beforeselect', this, record, index) !== false) {
// toggle checked field
record.set(this.checkField, !record.get(this.checkField));
// display full list
if (this.store.isFiltered()) {
this.doQuery(this.allQuery);
}
// set (update) value and fire event
if (record.data[this.valueField] === this.selectAllOn) {
if (record.get(this.checkField)) {
this.selectAll();
} else {
this.deselectAll();
}
} else {
this.setValue(this.getCheckedValue());
}
this.fireEvent('select', this, record, index);
}
} // eo function onSelect
// }}}
// {{{
/**
* Sets the value of the LovCombo
* @param {Mixed} v value
*/
, setValue: function(v) {
if (v) {
v = '' + v;
if (this.valueField) {
this.store.clearFilter();
this.store.each(function(r) {
if (r.data[this.valueField] === this.selectAllOn && this.selectAllCheck())
r.set(this.checkField, true);
else if (r.data[this.valueField] === this.selectAllOn)
r.set(this.checkField, null);
else {
var checked = !(!v.match(
'(^|' + RegExp.escape(this.separator) + ')' + RegExp.escape(r.get(this.valueField))
+ '(' + RegExp.escape(this.separator) + '|$)'))
;
r.set(this.checkField, checked);
}
}, this);
this.value = this.getCheckedValue();
this.setRawValue(this.getCheckedDisplay());
if (this.hiddenField) {
this.hiddenField.value = this.value;
}
}
else {
this.value = v;
this.setRawValue(v);
if (this.hiddenField) {
this.hiddenField.value = v;
}
}
if (this.el) {
this.el.removeClass(this.emptyClass);
}
}
else {
this.clearValue();
}
} // eo function setValue
// }}}
// {{{
/**
* Selects all items
*/
, selectAll: function() {
this.store.each(function(record) {
// toggle checked field
record.set(this.checkField, true);
}, this);
//display full list
this.doQuery(this.allQuery);
this.setValue(this.getCheckedValue());
} // eo full selectAll
// }}}
// {{{
/**
* Deselects all items. Synonym for clearValue
*/
, deselectAll: function() {
this.clearValue();
} // eo full deselectAll
// }}}
}); // eo extend
// register xtype
Ext.reg('lovcombo', Ext.ux.form.LovCombo);
// vim: ts=4:sw=4:nu:fdc=4:nospell
/**
* Ext.ux.form.LovCombo, List of Values Combo
*
* @author Ing. Jozef Sakáloš
* @copyright (c) 2008, by Ing. Jozef Sakáloš
* @date 16. April 2008
* @version $Id: Ext.ux.form.LovCombo.js 285 2008-06-06 09:22:20Z jozo $
*
* @license Ext.ux.form.LovCombo.js is licensed under the terms of the Open Source
* LGPL 3.0 license. Commercial use is permitted to the extent that the
* code/component(s) do NOT become part of another Open Source or Commercially
* licensed development library or toolkit without explicit permission.
*
* License details: http://www.gnu.org/licenses/lgpl.html
*/
/*global Ext */
// add RegExp.escape if it has not been already added
if ('function' !== typeof RegExp.escape) {
RegExp.escape = function(s) {
if ('string' !== typeof s) {
return s;
}
// Note: if pasting from forum, precede ]// with backslash manually
return s.replace(/([.*+?^=!:${}()|[/]////])/g, '//$1');
}; // eo function escape
}
// create namespace
Ext.ns('Ext.ux.form');
/**
*
* @class Ext.ux.form.LovCombo
* @extends Ext.form.ComboBox
*/
Ext.ux.form.LovCombo = Ext.extend(Ext.form.ComboBox, {
// {{{
// configuration options
/**
* @cfg {String} selectAllOn the value of the option used as
* the select-all / deselect-all trigger
*/
selectAllOn: null,
/**
* @cfg {String} checkField name of field used to store checked state.
* It is automatically added to existing fields.
* Change it only if it collides with your normal field.
*/
checkField: 'checked'
/**
* @cfg {String} separator separator to use between values and texts for getValue and submission
*/
, separator: ','
/**
* @cfg {String} displaySeparator displaySeparator to use between values and texts for display
*/
, displaySeparator: ','
/**
* @cfg {String/Array} tpl Template for items.
* Change it only if you know what you are doing.
*/
// }}}
// {{{
, initComponent: function() {
// template with checkbox
if (!this.tpl) {
this.tpl =
'<tpl for=".">'
+ '<div class="x-combo-list-item">'
+ '<img src="' + Ext.BLANK_IMAGE_URL + '" mce_src="' + Ext.BLANK_IMAGE_URL + '" '
+ 'class="ux-lovcombo-icon ux-lovcombo-icon-'
//+'{[values.' + this.checkField + '?"checked":values.' + this.checkField + '===null?"mixed":"unchecked"' + ']}">'
+ '{[values.' + this.checkField + '?"checked":"unchecked"' + ']}">'
+ '<div class="ux-lovcombo-item-text">{' + (this.displayField || 'text') + '}</div>'
+ '</div>'
+ '</tpl>'
;
}
// call parent
Ext.ux.form.LovCombo.superclass.initComponent.apply(this, arguments);
// install internal event handlers
this.on({
scope: this
, beforequery: this.onBeforeQuery
//,blur:this.onRealBlur
});
// remove selection from input field
this.onLoad = this.onLoad.createSequence(function() {
if (this.el) {
var v = this.el.dom.value;
this.el.dom.value = '';
this.el.dom.value = v;
}
});
} // e/o function initComponent
// }}}
// {{{
/**
* Disables default tab key bahavior
* @private
*/
, initEvents: function() {
Ext.ux.form.LovCombo.superclass.initEvents.apply(this, arguments);
// disable default tab handling - does no good
this.keyNav.tab = false;
} // eo function initEvents
// }}}
// {{{
/**
* clears value
*/
, clearValue: function() {
this.value = '';
this.setRawValue(this.value);
this.store.clearFilter();
this.store.each(function(r) {
r.set(this.checkField, false);
}, this);
if (this.hiddenField) {
this.hiddenField.value = '';
}
this.applyEmptyText();
} // eo function clearValue
// }}}
// {{{
/**
* @return {String} separator (plus space) separated list of selected displayFields
* @private
*/
, getCheckedDisplay: function() {
var re = new RegExp(RegExp.escape(this.separator), "g");
return this.getCheckedValue(this.displayField).replace(re, RegExp.escape(this.displaySeparator) + ' ');
} // eo function getCheckedDisplay
// }}}
// {{{
/**
* @return {String} separator separated list of selected valueFields
* @private
*/
, getCheckedValue: function(field) {
field = field || this.valueField;
var c = [];
// store may be filtered so get all records
var snapshot = this.store.snapshot || this.store.data;
snapshot.each(function(r) {
if (r.get(this.checkField) && r.data[this.valueField] !== this.selectAllOn)
c.push(r.get(field));
}, this);
return c.join(this.separator);
} // eo function getCheckedValue
, selectAllCheck: function() {
var snapshot = this.store.snapshot || this.store.data;
var selectAll = true;
snapshot.each(function(r) {
if (r.data[this.valueField] !== this.selectAllOn && !r.get(this.checkField)) {
selectAll = false;
return;
}
}, this);
return selectAll;
}
// }}}
// {{{
/**
* beforequery event handler - handles multiple selections
* @param {Object} qe query event
* @private
*/
, onBeforeQuery: function(qe) {
qe.query = qe.query.replace(new RegExp(this.getCheckedDisplay() + '[ ' + RegExp.escape(this.separator) + ']*'), '');
} // eo function onBeforeQuery
// }}}
// {{{
/**
* blur event handler - runs only when real blur event is fired
*/
, beforeBlur: function() {
this.list.hide();
var rv = this.getRawValue();
var rva = rv.split(new RegExp(RegExp.escape(this.displaySeparator) + ' *'));
var va = [];
var snapshot = this.store.snapshot || this.store.data;
// iterate through raw values and records and check/uncheck items
Ext.each(rva, function(v) {
snapshot.each(function(r) {
if (v === r.get(this.displayField)) {
va.push(r.get(this.valueField));
}
}, this);
}, this);
this.setValue(va.join(this.separator));
this.store.clearFilter();
} // eo function onRealBlur
// }}}
// {{{
/**
* Combo's onSelect override
* @private
* @param {Ext.data.Record} record record that has been selected in the list
* @param {Number} index index of selected (clicked) record
*/
, onSelect: function(record, index) {
if (this.fireEvent('beforeselect', this, record, index) !== false) {
// toggle checked field
record.set(this.checkField, !record.get(this.checkField));
// display full list
if (this.store.isFiltered()) {
this.doQuery(this.allQuery);
}
// set (update) value and fire event
if (record.data[this.valueField] === this.selectAllOn) {
if (record.get(this.checkField)) {
this.selectAll();
} else {
this.deselectAll();
}
} else {
this.setValue(this.getCheckedValue());
}
this.fireEvent('select', this, record, index);
}
} // eo function onSelect
// }}}
// {{{
/**
* Sets the value of the LovCombo
* @param {Mixed} v value
*/
, setValue: function(v) {
if (v) {
v = '' + v;
if (this.valueField) {
this.store.clearFilter();
this.store.each(function(r) {
if (r.data[this.valueField] === this.selectAllOn && this.selectAllCheck())
r.set(this.checkField, true);
else if (r.data[this.valueField] === this.selectAllOn)
r.set(this.checkField, null);
else {
var checked = !(!v.match(
'(^|' + RegExp.escape(this.separator) + ')' + RegExp.escape(r.get(this.valueField))
+ '(' + RegExp.escape(this.separator) + '|$)'))
;
r.set(this.checkField, checked);
}
}, this);
this.value = this.getCheckedValue();
this.setRawValue(this.getCheckedDisplay());
if (this.hiddenField) {
this.hiddenField.value = this.value;
}
}
else {
this.value = v;
this.setRawValue(v);
if (this.hiddenField) {
this.hiddenField.value = v;
}
}
if (this.el) {
this.el.removeClass(this.emptyClass);
}
}
else {
this.clearValue();
}
} // eo function setValue
// }}}
// {{{
/**
* Selects all items
*/
, selectAll: function() {
this.store.each(function(record) {
// toggle checked field
record.set(this.checkField, true);
}, this);
//display full list
this.doQuery(this.allQuery);
this.setValue(this.getCheckedValue());
} // eo full selectAll
// }}}
// {{{
/**
* Deselects all items. Synonym for clearValue
*/
, deselectAll: function() {
this.clearValue();
} // eo full deselectAll
// }}}
}); // eo extend
// register xtype
Ext.reg('lovcombo', Ext.ux.form.LovCombo);
//测试数据
view plaincopy to clipboardprint?
{
xtype: 'lovcombo',
id: 'lovcombo',
hideOnSelect: false,
readOnly: false,
editable: false,
fieldLabel: "测试数据",
store:new Ext.data.SimpleStore({
id:0
,fields:['name']
,data:[
['Personnel']
,['Finance']
,['Management']
,['Production']
,['Users']
]
}),
typeAhead: true,
valueField: 'serviceHall_Name',
displayField: 'serviceHall_Name',
mode: 'local',
triggerAction: 'all',
emptyText: '请选择...',
selectOnFocus: true,
}
{
xtype: 'lovcombo',
id: 'lovcombo',
hideOnSelect: false,
readOnly: false,
editable: false,
fieldLabel: "测试数据",
store:new Ext.data.SimpleStore({
id:0
,fields:['name']
,data:[
['Personnel']
,['Finance']
,['Management']
,['Production']
,['Users']
]
}),
typeAhead: true,
valueField: 'serviceHall_Name',
displayField: 'serviceHall_Name',
mode: 'local',
triggerAction: 'all',
emptyText: '请选择...',
selectOnFocus: true,
}
//使用jsonstore
view plaincopy to clipboardprint?
var store = new Ext.data.JsonStore({
url: "Module/ServiceHall/ServiceHall.asmx/ShowServiceHall",
fields: ['name']
});
store.load();
{
xtype: 'lovcombo',
id: 'lovcombo',
hideOnSelect: false,
readOnly: false,
editable: false,
fieldLabel: "测试数据",
store:store,
typeAhead: true,
valueField: 'id',
displayField: 'name',
mode: 'local',
triggerAction: 'all',
emptyText: '请选择...',
selectOnFocus: true,
}
:[{"name":"数据1","id":"1"},{"name":"数据2","id":"2"}]
var store = new Ext.data.JsonStore({
url: "Module/ServiceHall/ServiceHall.asmx/ShowServiceHall",
fields: ['name']
});
store.load();
{
xtype: 'lovcombo',
id: 'lovcombo',
hideOnSelect: false,
readOnly: false,
editable: false,
fieldLabel: "测试数据",
store:store,
typeAhead: true,
valueField: 'id',
displayField: 'name',
mode: 'local',
triggerAction: 'all',
emptyText: '请选择...',
selectOnFocus: true,
}
返回数据格式示例:[{"name":"数据1","id":"1"},{"name":"数据2","id":"2"}]
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/windxxf/archive/2010/08/19/5823411.aspx
- lovCombo
- ext.ux.form.lovcombo
- ExtJS:下拉多选框lovcombo-ext
- ExtJS:下拉多选框lovcombo-ext
- ExtJs多选下拉框控件LovCombo
- extjs多选下拉框lovcombo实现
- Extjs3.2.0 使用插件 LovCombo 多选下拉之心路历程
- 关于ext多行下拉框的问题 lovcombo
- Ext2.3 lovCombo勾选多个值,失去焦点后文本框清空问题
- Extjs 多选下拉框 Ext.ux.form.LovCombo默认选择及其它BUG修复版支持多选/全选/全不选ext3.x
- Extjs 多选下拉框 Ext.ux.form.LovCombo默认选择及其它BUG修复版支持多选/全选/全不选ext3.x
- Ext.ux.form.LovCombo.js在ext3.4.0下选择多个选项,当鼠标离开,已选择项目就消失了的解决办法
- 全面解析MFC应用程序中处理消息的顺序 (转)
- linux大文件
- 变革时代来临 IT人需早做准备
- 获得联系人
- 2011年互联网行业火爆领域预测
- lovCombo
- sicily 1002
- Box2D支持WP7~
- Jsp中get和post的区别
- Android 界面刷新
- Cursor
- 如何操作INI文件?
- Activity透明
- 存储过程分页