读书人

Ext 多选上拉 MultiComBox

发布时间: 2012-09-23 10:28:10 作者: rapoo

Ext 多选下拉 MultiComBox

下面介绍MultiComboBox的使用方式,大家先看看下面的代码:

+ + this.displayField + '}"+ width="20">    </span>{' + this.displayField + '}</div></tpl>'; }
  • this.view = new <span class="hilite1">Ext</span> .DataView({
  • applyTo: this.innerList, tpl: this.tpl,
  • singleSelect: true, selectedClass: this.selectedClass,
  • itemSelector: this.itemSelector || '.' + cls + '-item' });
  • this.view.on('click', this.onViewClick, this);
  • this.bindStore(this.store, true);
  • if(this.resizable){
  • this.resizer = new <span class="hilite1">Ext</span> .Resizable(this.list, {
  • pinned:true, handles:'se' });
  • this.resizer.on('resize', function(r, w, h){ this.maxHeight = h-this.handleHeight-this.list.getFrameWidth('tb')-this.assetHeight;
  • this.listWidth = w; this.innerList.setWidth(w - this.list.getFrameWidth('lr'));
  • this.restrictHeight(); }, this);
  • this[this.pageSize?'footer':'innerList'].setStyle('margin-bottom', this.handleHeight+'px'); }
  • } },
  • bindStore : function(store, initial){
  • if(this.store && !initial){ this.store.un('beforeload', this.onBeforeLoad, this);
  • this.store.un('load', this.onLoad, this); this.store.un('loadexception', this.collapse, this);
  • if(!store){ this.store = null;
  • if(this.view){ this.view.setStore(null);
  • } }
  • } if(store){
  • this.store = <span class="hilite1">Ext</span> .StoreMgr.lookup(store);
  • this.store.on('beforeload', this.onBeforeLoad, this);
  • this.store.on('load', this.onLoad, this); this.store.on('loadexception', this.collapse, this);
  • if(this.view){
  • this.view.setStore(store); }
  • } },
  • // private
  • initEvents : function(){ <span class="hilite1">Ext</span>
  • .form.ComboBox.superclass.initEvents.call(this);
  • this.keyNav = new <span class="hilite1">Ext</span> .KeyNav(this.el, {
  • "up" : function(e){ this.inKeyMode = true;
  • this.selectPrev(); },
  • "down" : function(e){
  • if(!this.isExpanded()){ this.onTriggerClick();
  • }else{ this.inKeyMode = true;
  • this.selectNext(); }
  • },
  • "enter" : function(e){ this.onViewClick();
  • //return true; },
  • "esc" : function(e){
  • this.collapse(); },
  • "tab" : function(e){
  • this.onViewClick(false); return true;
  • },
  • scope : this,
  • doRelay : function(foo, bar, hname){ if(hname == 'down' || this.scope.isExpanded()){
  • return <span class="hilite1">Ext</span> .KeyNav.prototype.doRelay.apply(this, arguments);
  • } return true;
  • },
  • forceKeyDown : true });
  • this.queryDelay = Math.max(this.queryDelay || 10, this.mode == 'local' ? 10 : 250);
  • this.dqTask = new <span class="hilite1">Ext</span> .util.DelayedTask(this.initQuery, this);
  • if(this.typeAhead){ this.taTask = new <span class="hilite1">Ext</span>
  • .util.DelayedTask(this.onTypeAhead, this); }
  • if(this.editable !== false){ this.el.on("keyup", this.onKeyUp, this);
  • } if(this.forceSelection){
  • this.on('blur', this.doForce, this); }
  • },
  • onDestroy : function(){ if(this.view){
  • this.view.el.removeAllListeners(); this.view.el.remove();
  • this.view.purgeListeners(); }
  • if(this.list){ this.list.destroy();
  • } this.bindStore(null);
  • <span class="hilite1">Ext</span> .form.ComboBox.superclass.onDestroy.call(this);
  • },
  • // private fireKey : function(e){
  • if(e.isNavKeyPress() && !this.list.isVisible()){ this.fireEvent("specialkey", this, e);
  • } },
  • // private
  • onResize: function(w, h){ <span class="hilite1">Ext</span>
  • .form.ComboBox.superclass.onResize.apply(this, arguments); if(this.list && this.listWidth === undefined){
  • var lw = Math.max(w, this.minListWidth); this.list.setWidth(lw);
  • this.innerList.setWidth(lw - this.list.getFrameWidth('lr')); }
  • },
  • // private onDisable: function(){
  • <span class="hilite1">Ext</span> .form.ComboBox.superclass.onDisable.apply(this, arguments);
  • if(this.hiddenField){ this.hiddenField.disabled = this.disabled;
  • } },
  • setEditable : function(value){ if(value == this.editable){
  • return; }
  • this.editable = value; if(!value){
  • this.el.dom.setAttribute('readOnly', true); this.el.on('mousedown', this.onTriggerClick, this);
  • this.el.addClass('x-combo-noedit'); }else{
  • this.el.dom.setAttribute('readOnly', false); this.el.un('mousedown', this.onTriggerClick, this);
  • this.el.removeClass('x-combo-noedit'); }
  • },
  • // private onBeforeLoad : function(){
  • if(!this.hasFocus){ return;
  • } this.innerList.update(this.loadingText ?
  • '<div class="loading-indicator">'+this.loadingText+'</div>' : ''); this.restrictHeight();
  • this.selectedIndex = -1; },
  • // private
  • onLoad : function(){ if(!this.hasFocus){
  • return; }
  • if(this.store.getCount() > 0){ this.expand();
  • this.restrictHeight(); if(this.lastQuery == this.allQuery){
  • if(this.editable){ this.el.dom.select();
  • } if(!this.selectByValue(this.value, true)){
  • this.select(0, true); }
  • }else{ this.selectNext();
  • if(this.typeAhead && this.lastKey != <span class="hilite1">Ext</span> .EventObject.BACKSPACE && this.lastKey != <span class="hilite1">Ext</span>
  • .EventObject.DELETE){ this.taTask.delay(this.typeAheadDelay);
  • } }
  • }else{ this.onEmptyResults();
  • } },
  • // private
  • onTypeAhead : function(){ if(this.store.getCount() > 0){
  • var r = this.store.getAt(0); var newValue = r.data[this.displayField];
  • var len = newValue.length; var selStart = this.getRawValue().length;
  • if(selStart != len){ this.setRawValue(newValue);
  • this.selectText(selStart, newValue.length); }
  • } },
  • // private onSelect : function(record, index){
  • if(this.fireEvent('beforeselect', this, record, index) !== false){ var r = this.store.getAt(index);
  • var newValue = r.data[this.displayField]; var check=document.getElementById("checkBox_"+newValue);
  • if(check.className=="checked"){ check.className="unchecked"
  • }else{ check.className="checked"
  • } var value="";
  • var hiddenValue=""; for(var i=0;i<this.store.data.length;i++){
  • var r = this.store.getAt(i); newValue = r.data[this.displayField];
  • check=document.getElementById("checkBox_"+newValue); if(check.className=="checked"){
  • value+= r.data[this.displayField]+this.displaySeparator; hiddenValue+= r.data[this.valueField]+this.valueSeparator;
  • } }
  • if(value.length>1){ value=value.substring(0,value.length-this.displaySeparator.length);
  • } if(hiddenValue.length>1){
  • hiddenValue=hiddenValue.substring(0,value.length-this.valueSeparator.length); }
  • this.setValue(value); this.hiddenField.value=hiddenValue;
  • this.fireEvent('select', this, record, index); }
  • }, getValue : function(){
  • if(this.valueField){ return typeof this.value != 'undefined' ? this.value : '';
  • }else{ return <span class="hilite1">Ext</span>
  • .form.ComboBox.superclass.getValue.call(this); }
  • },
  • /** * Clears any text/value currently set in the field
  • */ clearValue : function(){
  • if(this.hiddenField){ this.hiddenField.value = '';
  • } this.setRawValue('');
  • this.lastSelectionText = ''; this.applyEmptyText();
  • }, setValue : function(v){
  • var text = v; if(this.valueField){
  • var r = this.findRecord(this.valueField, v); if(r){
  • text = r.data[this.displayField]; }else if(this.valueNotFoundText !== undefined){
  • text = this.valueNotFoundText; }
  • } this.lastSelectionText = text;
  • <span class="hilite1">Ext</span> .form.ComboBox.superclass.setValue.call(this, text);
  • this.value = v; },
  • // private
  • findRecord : function(prop, value){ var record;
  • if(this.store.getCount() > 0){ this.store.each(function(r){
  • if(r.data[prop] == value){ record = r;
  • return false; }
  • }); }
  • return record; },
  • // private
  • onViewMove : function(e, t){ this.inKeyMode = false;
  • },
  • // private onViewOver : function(e, t){
  • if(this.inKeyMode){ // prevent key nav and mouse over conflicts return;
  • } var item = this.view.findItemFromChild(t);
  • if(item){ var index = this.view.indexOf(item);
  • this.select(index, false); }
  • },
  • // private onViewClick : function(doFocus){
  • var index = this.view.getSelectedIndexes()[0]; var r = this.store.getAt(index);
  • if(r){ this.onSelect(r, index);
  • } if(doFocus !== false){
  • this.el.focus(); }
  • },
  • // private restrictHeight : function(){
  • this.innerList.dom.style.height = ''; var inner = this.innerList.dom;
  • var fw = this.list.getFrameWidth('tb'); var h = Math.max(inner.clientHeight, inner.offsetHeight, inner.scrollHeight);
  • this.innerList.setHeight(h < this.maxHeight ? 'auto' : this.maxHeight); this.list.beginUpdate();
  • this.list.setHeight(this.innerList.getHeight()+fw+(this.resizable?this.handleHeight:0)+this.assetHeight); this.list.alignTo(this.el, this.listAlign);
  • this.list.endUpdate(); },
  • // private
  • onEmptyResults : function(){ this.collapse();
  • },
  • /** * Returns true if the dropdown list is expanded, else false.
  • */ isExpanded : function(){
  • return this.list && this.list.isVisible(); },
  • selectByValue : function(v, scrollIntoView){ if(v !== undefined && v !== null){
  • var r = this.findRecord(this.valueField || this.displayField, v); if(r){
  • this.select(this.store.indexOf(r), scrollIntoView); return true;
  • } }
  • return false; },
  • select : function(index, scrollIntoView){
  • this.selectedIndex = index; this.view.select(index);
  • if(scrollIntoView !== false){ var el = this.view.getNode(index);
  • if(el){ this.innerList.scrollChildIntoView(el, false);
  • } }
  • },
  • // private
  • selectNext : function(){ var ct = this.store.getCount();
  • if(ct > 0){ if(this.selectedIndex == -1){
  • this.select(0); }else if(this.selectedIndex < ct-1){
  • this.select(this.selectedIndex+1); }
  • } },
  • // private
  • selectPrev : function(){ var ct = this.store.getCount();
  • if(ct > 0){ if(this.selectedIndex == -1){
  • this.select(0); }else if(this.selectedIndex != 0){
  • this.select(this.selectedIndex-1); }
  • } },
  • // private
  • onKeyUp : function(e){ if(this.editable !== false && !e.isSpecialKey()){
  • this.lastKey = e.getKey(); this.dqTask.delay(this.queryDelay);
  • } },
  • // private
  • validateBlur : function(){ return !this.list || !this.list.isVisible();
  • },
  • // private initQuery : function(){
  • this.doQuery(this.getRawValue()); },
  • // private
  • doForce : function(){ if(this.el.dom.value.length > 0){
  • this.el.dom.value = this.lastSelectionText === undefined ? '' : this.lastSelectionText;
  • this.applyEmptyText(); }
  • }, doQuery : function(q, forceAll){
  • if(q === undefined || q === null){ q = '';
  • } var qe = {
  • query: q, forceAll: forceAll,
  • combo: this, cancel:false
  • }; if(this.fireEvent('beforequery', qe)===false || qe.cancel){
  • return false; }
  • q = qe.query; forceAll = qe.forceAll;
  • if(forceAll === true || (q.length >= this.minChars)){ if(this.lastQuery !== q){
  • this.lastQuery = q; if(this.mode == 'local'){
  • this.selectedIndex = -1; if(forceAll){
  • this.store.clearFilter(); }else{
  • this.store.filter(this.displayField, q); }
  • this.onLoad(); }else{
  • this.store.baseParams[this.queryParam] = q; this.store.load({
  • params: this.getParams(q) });
  • this.expand(); }
  • }else{ this.selectedIndex = -1;
  • this.onLoad(); }
  • } },
  • // private
  • getParams : function(q){ var p = {};
  • //p[this.queryParam] = q; if(this.pageSize){
  • p.start = 0; p.limit = this.pageSize;
  • } return p;
  • }, /**
  • * Hides the dropdown list if it is currently expanded. Fires the 'collapse' event on completion. */
  • collapse : function(){ if(!this.isExpanded()){
  • return; }
  • this.list.hide(); <span class="hilite1">Ext</span>
  • .getDoc().un('mousewheel', this.collapseIf, this); <span class="hilite1">Ext</span>
  • .getDoc().un('mousedown', this.collapseIf, this); this.fireEvent('collapse', this);
  • }, // private
  • collapseIf : function(e){ if(!e.within(this.wrap) && !e.within(this.list)){
  • this.collapse(); }
  • },
  • /** * Expands the dropdown list if it is currently hidden. Fires the 'expand' event on completion.
  • */ expand : function(){
  • if(this.isExpanded() || !this.hasFocus){ return;
  • } this.list.alignTo(this.wrap, this.listAlign);
  • var hvalueArray=this.hiddenField.value.split(this.valueSeparator); for(var i=0;i<this.store.data.length;i++){
  • var r = this.store.getAt(i); var newValue = r.data[this.displayField];
  • var v=r.data[this.valueField]; for(var j=0;j<hvalueArray.length;j++){
  • if(hvalueArray[j]==v){ document.getElementById("checkBox_"+newValue).className="checked";
  • } }
  • }
  • this.list.show(); <span class="hilite1">Ext</span>
  • .getDoc().on('mousewheel', this.collapseIf, this); <span class="hilite1">Ext</span>
  • .getDoc().on('mousedown', this.collapseIf, this); this.fireEvent('expand', this);
  • },
  • // private // Implements the default empty TriggerField.onTriggerClick function
  • onTriggerClick : function(){ if(this.disabled){
  • return; }
  • if(this.isExpanded()){ this.collapse();
  • this.el.focus(); }else {
  • this.onFocus({}); if(this.triggerAction == 'all') {
  • this.doQuery(this.allQuery, true); } else {
  • this.doQuery(this.getRawValue()); }
  • this.el.focus(); }
  • } });
  • <span class="hilite1">Ext</span> .reg('multicombo', <span class="hilite1">Ext</span>
  • .form.MultiComboBox);

    ext-all.css文件最后添加两行支持样式:

    1.checked{background-image:url(../images/default/menu/checked.gif)}

    2.unchecked{background-image:url(../images/default/menu/unchecked.gif)}

  • 读书人网 >Web前端

    热点推荐