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


Posted in Javascript onMarch 20, 2017

一、效果如图所示

特点:

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

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

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

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

二、插件源码如下:

/**
* 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 :'
<span style="color:red;font-weight:bold" data-qtip="必填项">*</span>'
,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表单输入框异步校验的插件实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery1.83 之前所有与异步列队相关的模块详细介绍
Nov 13 Javascript
js实现无需数据库的县级以上联动行政区域下拉控件
Aug 14 Javascript
jQuery实现首页顶部可伸缩广告特效代码
Apr 15 Javascript
javascript作用域问题实例分析
Jul 13 Javascript
WordPress 单页面上一页下一页的实现方法【附代码】
Mar 10 Javascript
Angular中$cacheFactory的作用和用法实例详解
Aug 19 Javascript
详解基于Bootstrap+angular的一个豆瓣电影app
Jun 26 Javascript
详解如何使用webpack+es6开发angular1.x
Aug 16 Javascript
微信小程序实现自上而下字幕滚动
Jul 14 Javascript
vue项目初始化到登录login页面的示例
Oct 31 Javascript
解决Vue.js应用回退或刷新界面时提示用户保存修改问题
Nov 24 Javascript
jQuery treeview树形结构应用
Mar 24 jQuery
js实现鼠标拖动功能
Mar 20 #Javascript
基于vue2的table分页组件实现方法
Mar 20 #Javascript
详解Weex基于Vue2.0开发模板搭建
Mar 20 #Javascript
基于vue.js实现侧边菜单栏
Mar 20 #Javascript
微信小程序 参数传递实例代码
Mar 20 #Javascript
vue.js指令v-model使用方法
Mar 20 #Javascript
微信小程序中子页面向父页面传值实例详解
Mar 20 #Javascript
You might like
PHP网上调查系统
2006/10/09 PHP
使用Apache的htaccess防止图片被盗链的解决方法
2013/04/27 PHP
PHP小教程之实现双向链表
2014/06/12 PHP
用PHP代替JS玩转DOM的思路及示例代码
2014/06/15 PHP
PHP开发实现快递查询功能详解
2019/04/08 PHP
表单提交验证类
2006/07/14 Javascript
动态刷新 dorado树的js代码
2009/06/12 Javascript
调用js时ie6和ie7,ff的区别
2009/08/19 Javascript
JS按位非(~)运算符与~~运算符的理解分析
2011/07/31 Javascript
Javascript中的delete介绍
2012/09/02 Javascript
基于JavaScript实现继承机制之原型链(prototype chaining)的详解
2013/05/07 Javascript
jquery UI Datepicker时间控件的使用方法(基础版)
2015/11/07 Javascript
JS组件Bootstrap ContextMenu右键菜单使用方法
2016/04/17 Javascript
JavaScript生成验证码并实现验证功能
2016/09/24 Javascript
利用纯Vue.js构建Bootstrap组件
2016/11/03 Javascript
详解Node.js 命令行程序开发教程
2017/06/07 Javascript
JavaScript数组push方法使用注意事项
2017/10/30 Javascript
vue渲染时闪烁{{}}的问题及解决方法
2018/03/28 Javascript
vue 中filter的多种用法
2018/04/26 Javascript
微信公众号平台接口开发 获取微信服务器IP地址方法解析
2019/08/14 Javascript
解决vue项目刷新后,导航菜单高亮显示的位置不对问题
2019/11/01 Javascript
从Node.js事件触发器到Vue自定义事件的深入讲解
2020/06/26 Javascript
vue内置组件keep-alive事件动态缓存实例
2020/10/30 Javascript
python 域名分析工具实现代码
2009/07/15 Python
跟老齐学Python之玩转字符串(3)
2014/09/14 Python
Python 中包/模块的 `import` 操作代码
2019/04/22 Python
python中property和setter装饰器用法
2019/12/19 Python
Jupyter notebook无法导入第三方模块的解决方式
2020/04/15 Python
利用python 读写csv文件
2020/09/10 Python
爱尔兰旅游网站:ebookers.ie
2020/01/24 全球购物
Servlet的生命周期
2013/08/25 面试题
岗位职责的含义
2013/11/17 职场文书
基层工作经历证明
2014/01/13 职场文书
办公室禁烟通知
2015/04/23 职场文书
图书馆义工感想
2015/08/07 职场文书
复制别人的成功真的会成功吗?
2019/10/17 职场文书