背景:有一些时候我们处理的数据本身就是树状的结构,当我们需要在从这些数据中做选择的时候,希望出来的数据也是树状,以方便在逻辑上区分.
实现方法:扩展和树相关的类,使得他们可以用于选择.
实现代码:
Ext.ux.OptionTreeNode
Ext.ux.OptionTreeNode=function(attributes)
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
data:image/s3,"s3://crabby-images/f4fe2/f4fe2905e6a68eecdb5a9c900ae477a6bd055e40" alt=""
{
Ext.ux.OptionTreeNode.superclass.constructor.call(this,attributes);
this.value=attributes.value||'';
this.proirity=attributes.proirity||'';
};
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.extend(Ext.ux.OptionTreeNode ,Ext.tree.TreeNode,
{
});
Ext.ux.AsyncOptionTreeNode
Ext.ux.AsyncOptionTreeNode=function(attributes)
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
data:image/s3,"s3://crabby-images/f4fe2/f4fe2905e6a68eecdb5a9c900ae477a6bd055e40" alt=""
{
Ext.ux.AsyncOptionTreeNode.superclass.constructor.call(this,attributes);
this.value=attributes.value||'';
this.proirity=attributes.proirity||'';
};
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.extend(Ext.ux.AsyncOptionTreeNode ,Ext.tree.AsyncTreeNode,
{
});
Ext.ux.OptionTreeLoader
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.ux.OptionTreeLoader = function(config)
{
Ext.ux.OptionTreeLoader.superclass.constructor.call(this, config);
};
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.extend(Ext.ux.OptionTreeLoader, Ext.tree.TreeLoader,
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
createNode : function(attr)
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
Ext.apply(attr, this.baseAttr ||
{});
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(typeof attr.uiProvider == 'string')
{
attr.uiProvider = this.uiProviders[attr.uiProvider] || eval(attr.uiProvider);
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
return(attr.leaf ?
new Ext.ux.OptionTreeNode(attr) :
new Ext.ux.AsyncOptionTreeNode(attr));
}
});
Ext.ux.TreeComboBox
Ext.ux.TreeComboBox=function(config)
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
data:image/s3,"s3://crabby-images/f4fe2/f4fe2905e6a68eecdb5a9c900ae477a6bd055e40" alt=""
{
var treeId=config.hiddenName + '-tree'+Ext.id();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
var treeConfig = Ext.apply(
{},
{
border:false,
id:treeId
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
},
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
loader: new Ext.ux.OptionTreeLoader(
{dataUrl:'tree/optionNodes.html'}),
border:false,
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
root:new Ext.ux.AsyncOptionTreeNode(
{text: '根节点',id:'0',value:''})}
);
this.tree=new Ext.tree.TreePanel(treeConfig);
//this.hiddenField=new Ext.form.Hidden({name:config.valueName});
var _combobox=this;
var _tree=this.tree;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
_tree.on('click',function(node)
{
var record=_combobox.setValueAndText(node.value,node.text);
_combobox.collapse();
_combobox.fireEvent('select', _combobox, record, 0);
});
this.onExpand=function()
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
_tree.render(treeId);
}
Ext.ux.TreeCombobox.superclass.constructor.call(this,Ext.apply(
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
data:image/s3,"s3://crabby-images/b5d63/b5d63edfaa699a66c09796cd84755e3277e358af" alt=""
{
hiddenName:config.hiddenName,
//name:config.name,
fieldLabel:config.fieldLabel,
emptyText:config.emptyText,
valueField:config.valueField||'value',
displayField:config.displayField||'text',
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
store:new Ext.data.SimpleStore(
{fields:[],data:[[]]}),
editable:false,
shadow:false,
autoScroll:true,
mode: 'local',
triggerAction:'all',
maxHeight: config.maxHeight||200,
tpl: '<tpl for="."><div style="height:'+config.maxHeight+'px"><div id="'+treeId+'"></div></div></tpl>',
selectedClass:'',
onSelect:Ext.emptyFn
},config
));
};
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.extend(Ext.ux.TreeComboBox ,Ext.form.ComboBox,
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
onRender : function(ct, position)
{
Ext.ux.TreeComboBox.superclass.onRender.apply(this, arguments);
this.on("expand",this.onExpand,this);
if(this.allowBlanl==false)
this.setDefault();
},
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
setValue : function(v)
{
if(v)
this. setValueAndText(v.code,v.name);
else
Ext.form.ComboBox.superclass.setValue.call(this, v);
},
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
setValueAndText : function(v,t)
{
//Ext.log(v+t);
var text = v==''?'根节点':t;
this.lastSelectionText = text;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(this.hiddenField)
{
this.hiddenField.value = v;
}
Ext.form.ComboBox.superclass.setValue.call(this, text);
this.value = v;
var RecordType = Ext.data.Record.create([
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{name: this.valueField},
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{name: this.displayField}
]);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
var data=
{};
data[this.valueField]=v;
data[this.displayField]=t;
var record = new RecordType(data);
return record;
},
reset:function()
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{
this.tree.getRootNode().collapse();
Ext.ux.RegionField.superclass.reset.call(this);
}
});
例子:
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
var treeComboBox=new Ext.ux.TreeComboBox(
{
hiddenName:'treeComboBox',
fieldLabel:'树状选择框',
maxHeight:250,
treeWidth:200});
Let life be beautiful like summer flowers and death like autumn leaves.