ext js ajax表单校验,Extjs表单输入框异步校验的插件实现方法

一、效果如图所示

特点:

1、异步后台校验不会对用户操作产生阻塞感;

2、可在用户停止输入后自动校验,避免频繁进行无谓的后台校验;

3、以插件方式实现,方便使用;

dbb162a62450e344650c08927a5ed482.png

二、插件源码如下:

/**

* Created by jiawenjun on 2016/10/19.

*/

Ext.define('Ext.ux.plugins.FieldAjaxVerify',{

extend: 'Ext.AbstractPlugin',

alias: 'plugin.fieldajaxverify',

buffer:500,

url:'',

timeout:1000,

connectionFailure:'服务器连接失败'

init:function(field){

var me=this;

var params=me.params;

field.enableKeyEvents=true;

field.on('keyup',Ext.Function.createBuffered(function(field,e){

var value=field.getValue();

if(Ext.isEmpty(value)){

return;

}

var params=field.up('form').getValues();

if(Ext.isFunction(me.getParams)){

params=me.getParams(field,value);

}

Ext.Ajax.request({

url:me.url,

method:"POST",

params:params,

timeout: me.timeout,

contentType: "application/json; charset=utf-8",

success:function(response){

var obj = Ext.JSON.decode(response.responseText);

if(obj.result["success"]===true){

field.setValidation(true);

field.validate();

}else{

field.setValidation(obj.result["message"]);

field.validate();

}

},

failure:function(response){

var result = Ext.JSON.decode(response.responseText);

field.setValidation(me.connectionFailure);

field.validate();

}

});

},me.buffer))

}

});

三、应用方式

{name:'equipmentLedgerCategoryName',fieldLabel:'分类名称' ,allowBlank:false ,afterLabelTextTpl :'

*'

,plugins:{ptype: 'fieldajaxverify',url:'/service/uniquenessCheckName'}}

可用配置项:

1、buffer 毫秒数(在多少毫秒内用户没有输入操作则自动向后台发送验证请求

2、timeout ajax请求超时限制(毫秒数)

3、getParams(field,value) 自定义ajax参数内容

四、后台服务提供的数据格式

{

"resultCode" : 0,

"result" : {

"message" : "分类名称重复",

"success" : false

},

"msgId" : "41c2c52c-66d4-49c5-be52-0158e71cfe2c",

"success" : true

}

备注:在Extjs5.1下测试通过,有其他个性化需求可参考此插件进行实现,谢谢。

以上所述是小编给大家介绍的Extjs表单输入框异步校验的插件实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值