我在这里做了两件事:
1.使用'side'方式显示错误信息时,表单会缩进,我把这个效果去掉了
2.实现对勾和叹号图标的切换
注意:
我自定义了对勾的css样式,这里叫做'icon-yes'
//表单校验通过时显示对勾
//复写了Ext.layout.component.field.Field,该类用于处理表单的label和错误信息
//showValidIcon : Boolean
Ext.layout.component.field.Field.override({
getErrorStrategy: function() {
var me = this,
owner = me.owner,
strategies = me.errorStrategies,
msgTarget = owner.msgTarget;
var strategy = !owner.preventMark && Ext.isString(msgTarget) ? (strategies[msgTarget] || strategies.elementId) : strategies.none;
//给表单自定义showValidIcon:Boolean配置项
//如果showValidIcon=true,并且使用'side'方式,则使用对勾(否则是默认,不对原来的代码产生影响)
if(msgTarget == 'side' && owner.showValidIcon){
//初始化时不显示icon
if(owner.isIconInit){
owner.errorEl.setDisplayed(false);
owner.isIconInit = true;
}
//一旦校验,显示icon
owner.on('validitychange', function(me, valid){
me.errorEl.setDisplayed(true);
});
Ext.apply(strategy,{
//取消缩进效果
adjustHorizInsets : Ext.emptyFn,
layoutHoriz : function(ownerContext, owner, size) {
ownerContext.errorContext.setProp('x', size.width);
},
layoutVert: function(ownerContext, owner) {
ownerContext.errorContext.setProp('y', ownerContext.insets.top);
},
prepare : function(ownerContext, owner) {
var errorEl = owner.errorEl;
errorEl.addCls(Ext.baseCSSPrefix + 'form-invalid-icon');
errorEl.set({'data-errorqtip': owner.getActiveError() || ''});
var activeError = owner.getActiveError(),
hasError = !!activeError;
//切换对勾图标
errorEl[hasError ? 'removeCls' : 'addCls']('icon-yes');
Ext.layout.component.field.Field.initTip();
}
});
}
return strategy;
}
});