在extjs中,如何用method改变textfield中inputType的问题

2024-12-01 22:00:36
推荐回答(2个)
回答(1):

Ext的控件显示到页面上最后还是要转换成html标签的,textfield转换之后成为
而input的type属性是不能修改的,所以你只能另想办法了。
一种是创建两个textfield,一个inputType='text' 一个inputType='password',显示的时候显示一个隐藏另一个;
一种是创建一个textfield,
if(type == 'AUTHO') {
if(现有textfield不是password类型){
删除现有的textfield;
创建新的合适的textfield;
}
} else {
if(现有textfield不是text类型){
删除现有的textfield;
创建新的合适的textfield;
}
}

回答(2):

这样直接改变xtype 可能会有问题


因为有些xtype,例如Combo或者password 它有专有的属性


不是简单一个变更xtype的属性值就行了


建议还是写两个xtype组件,同时只显示一个组件 另一个隐藏


例如:


var cmp1 = Ext.getCmp("cmp1_id");
var cmp2 = Ext.getCmp("cmp2_id");
if(type == 'AUTHO') {
    cmp1.show();
    cmp2.hide();
}else {
    cmp1.hide();
    cmp2.show();
}