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

发布时间 - 2026-01-11 00:15:55    点击率:

一、效果如图所示

特点:

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

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

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

二、插件源码如下:

/**
* 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表单输入框异步校验的插件实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# extjs  # 表单  # extjs输入框  # JavaScript实现异步提交表单数据  # jquery.form.js异步提交表单详解  # 纯javascript的ajax实现php异步提交表单的简单实例  # javascript将异步校验表单改写为同步表单  # Javascript异步表单提交  # 图片上传  # 兼容异步模拟ajax技术  # JavaScript实现异步获取表单数据  # 小编  # 在此  # 可在  # 给大家  # 会对  # 自定义  # 所述  # 给我留言  # 必填  # 感谢大家  # 输入框  # 如图所示  # 疑问请  # 有任何  # 数据格式  # connectionFailure  # function  # init  # field 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  Python文件流缓冲机制_IO性能解析【教程】  如何确保西部建站助手FTP传输的安全性?  php结合redis实现高并发下的抢购、秒杀功能的实例  香港服务器网站卡顿?如何解决网络延迟与负载问题?  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  googleplay官方入口在哪里_Google Play官方商店快速入口指南  教你用AI将一段旋律扩展成一首完整的曲子  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  油猴 教程,油猴搜脚本为什么会网页无法显示?  微信小程序 配置文件详细介绍  零服务器AI建站解决方案:快速部署与云端平台低成本实践  Laravel如何生成URL和重定向?(路由助手函数)  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  详解MySQL数据库的安装与密码配置  教你用AI润色文章,让你的文字表达更专业  C语言设计一个闪闪的圣诞树  Python进程池调度策略_任务分发说明【指导】  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  装修招标网站设计制作流程,装修招标流程?  google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  Laravel如何使用Gate和Policy进行授权?(权限控制)  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  Laravel如何保护应用免受CSRF攻击?(原理和示例)  Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用  phpredis提高消息队列的实时性方法(推荐)  Laravel如何配置Horizon来管理队列?(安装和使用)  桂林网站制作公司有哪些,桂林马拉松怎么报名?  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】  如何用景安虚拟主机手机版绑定域名建站?  深圳网站制作平台,深圳市做网站好的公司有哪些?  Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制  Laravel定时任务怎么设置_Laravel Crontab调度器配置  Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置  Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明  如何用搬瓦工VPS快速搭建个人网站?  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  如何挑选高效建站主机与优质域名?  Laravel安装步骤详细教程_Laravel环境搭建指南  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  打造顶配客厅影院,这份100寸电视推荐名单请查收  Laravel怎么实现模型属性的自动加密  个人网站制作流程图片大全,个人网站如何注销?