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 相关文章推荐
JavaScript OOP面向对象介绍
Dec 02 Javascript
从面试题学习Javascript 面向对象(创建对象)
Mar 30 Javascript
常用的JQuery函数及功能小结
Mar 24 Javascript
[原创]Javascript 实现广告后加载 可加载百度谷歌联盟广告
May 11 Javascript
jQuery Ajax和getJSON获取后台普通json数据和层级json数据用法分析
Jun 08 Javascript
jqPlot jQuery绘图插件的使用
Jun 18 Javascript
Jquery获取当前城市的天气信息
Aug 05 Javascript
浅谈js的ajax的异步和同步请求的问题
Oct 07 Javascript
vue 2.0组件与v-model详解
Mar 27 Javascript
javascript基本常用排序算法解析
Sep 27 Javascript
修改npm全局安装模式的路径方法
May 15 Javascript
JS实现简单的表格增删
Jan 16 Javascript
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
咖啡机如何保养和日常清洁?
2021/03/03 冲泡冲煮
smarty缓存用法分析
2014/12/16 PHP
php生成excel列名超过26列大于Z时的解决方法
2014/12/29 PHP
JS的递增/递减运算符和带操作的赋值运算符的等价式
2007/12/08 Javascript
JS下高效拼装字符串的几种方法比较与测试代码
2010/04/15 Javascript
JavaScript实现拼音排序的方法
2012/11/20 Javascript
没有document.getElementByName方法
2013/08/19 Javascript
JS实现控制表格单元格垂直对齐的方法
2015/03/30 Javascript
微信小程序 自己制作小组件实例详解
2016/12/22 Javascript
jQuery Validate 数组 全部验证问题
2017/01/12 Javascript
get  post jsonp三种数据交互形式实例详解
2017/08/25 Javascript
详解如何在React组件“外”使用父组件的Props
2018/01/12 Javascript
使用vue + less 实现简单换肤功能的示例
2018/02/21 Javascript
vue拖拽组件使用方法详解
2018/12/01 Javascript
解决node-sass偶尔安装失败的方法小结
2018/12/05 Javascript
js防抖和节流的深入讲解
2018/12/06 Javascript
Javascript实现贪吃蛇小游戏(含详细注释)
2020/10/23 Javascript
优化Python代码使其加快作用域内的查找
2015/03/30 Python
python下paramiko模块实现ssh连接登录Linux服务器
2015/06/03 Python
Python实现批量压缩图片
2018/01/25 Python
PyQt实现界面翻转切换效果
2018/04/20 Python
python安装gdal的两种方法
2019/10/29 Python
tensorboard实现同时显示训练曲线和测试曲线
2020/01/21 Python
keras模型保存为tensorflow的二进制模型方式
2020/05/25 Python
html5 Canvas画图教程(7)—canvas里画曲线之quadraticCurveTo方法
2013/01/09 HTML / CSS
佛罗里达州印第安河新鲜水果:Hale Groves
2017/02/20 全球购物
Space NK英国站:英国热门美妆网站
2017/12/11 全球购物
ebookers英国:隶属全球最大的在线旅游公司Expedia
2017/12/28 全球购物
娇韵诗Clarins意大利官方网站:法国天然护肤品牌
2020/03/11 全球购物
大学军训感言1500字
2014/03/09 职场文书
体育专业自荐书
2014/05/29 职场文书
节能减耗标语
2014/06/21 职场文书
双拥工作宣传标语
2014/06/26 职场文书
活动总结范文
2014/08/30 职场文书
领导干部作风整顿剖析材料
2014/10/11 职场文书
学会用Python实现滑雪小游戏,再也不用去北海道啦
2021/05/20 Python