Ext.require([
'Ext.form.*',
'Ext.data.*'
]); Ext.onReady(function(){
Ext.apply(Ext.form.VTypes, {
repetition: function(val, field) { //返回true,则验证通过,否则验证失败
if (field.repetition) { //如果表单有使用repetition配置,repetition配置是一个JSON对象,该对象提供了一个名为targetCmpId的字段,该字段指定了需要进行比较的另一个组件ID。
var cmp = Ext.getCmp(field.repetition.targetCmpId); //通过targetCmpId的字段查找组件
if (Ext.isEmpty(cmp)) { //如果组件(表单)不存在,提示错误
Ext.MessageBox.show({
title: '错误',
msg: '发生异常错误,指定的组件未找到',
icon: Ext.Msg.ERROR,
buttons: Ext.Msg.OK
});
return false;
}
if (val == cmp.getValue()) { //取得目标组件(表单)的值,与宿主表单的值进行比较。
return true;
} else {
return false;
}
}
},
repetitionText: '两次输入的密码不一样'
}); Ext.define('example.contact', {
extend: 'Ext.data.Model',
fields: [
'name','stuid','password','password2','tel',
'sex','qq', 'email', 'grade_class',
{name: 'birthday', type: 'date', dateFormat: 'm/d/Y'}
]
}); Ext.define('example.fielderror', {
extend: 'Ext.data.Model',
fields: ['id', 'msg']
}); var formPanel = Ext.create('Ext.form.Panel', {
renderTo: 'form-ct',
url:'admin/userRegister', //如果要实现非AJAX表单提交就在这里加url
collapsible:true, method:'POST',
frame: true,
title:'注册',
width: '30%',
// left:1300,
bodyPadding: 5,
waitMsgTarget: true, fieldDefaults: {
labelAlign: 'right',
labelWidth: 85,
msgTarget: 'side'
}, // configure how to read the XML data
reader : Ext.create('Ext.data.reader.Xml', {
model: 'example.contact',
record : 'contact',
successProperty: '@success'
}), // configure how to read the XML errors
errorReader: Ext.create('Ext.data.reader.Xml', {
model: 'example.fielderror',
record : 'field',
successProperty: '@success'
}),
//实现非AJAX提交表单一定要加下面的两行! 下面的方法只适用于2.0版本
// onSubmit: Ext.emptyFn,
// submit: function() {
// this.getEl().dom.action='admin/userRegister'; //连接到服务器的url地址
// this.getEl().dom.submit();
// },
items: [{
xtype: 'fieldset', title: 'Information',
defaultType: 'textfield',
defaults: {
width: 280
},
items: [{
fieldLabel: '姓名',
allowBlank:false,
blankText :'请输入您的姓名',
emptyText: '请输入您的姓名',
name: 'name'
},
{
fieldLabel: '学号',
allowBlank:false,
blankText :'请输入您的学号',
emptyText: '请输入您的学号',
regex:/\d{9}$/,
vtype:'alphanum',
name: 'stuid'
}, {
inputType: 'password',
id: 'password',
name:'password',
maxLength: 15,
fieldLabel: '输入密码',
vtype:'alphanum',
allowBlank: false
},
{
inputType: 'password',
id: 'password2',
name:'password2',
maxLength: 15,
fieldLabel: '重复密码',
allowBlank: false,
vtype: 'repetition', //指定repetition验证类型
repetition: { targetCmpId: 'password' } //配置repetition验证,提供目标组件(表单)ID
},
{
fieldLabel: '电话',
// minLength:11,
// maxLength:11,
allowBlank:false,
blankText :'请输入合法的电话号码',
emptyText: '请输入您的电话',
regex:/\d{11}$/,
vtype:'alphanum',
name: 'tel'
},
{ xtype: 'combobox',
fieldLabel: '性别',
allowBlank:false,
blankText :'你没有性别??!', name: 'sex',
store: Ext.create('Ext.data.ArrayStore', {
fields: ['usex', 'sex'],
// data : Ext.example.states // from states.js
data:[['01','男'],['02','女'],['03','为什么会有这个选项...']
]
}),
valueField: 'usex',
displayField: 'sex',
typeAhead: true,
queryMode: 'local' },
{
fieldLabel: 'qq',
allowBlank:false,
minLength:5,
maxLength:10,
blankText :'请输入合法的QQ号码',
emptyText: '请输入您的QQ',
vtype:'alphanum',
name: 'qq'
},
{
fieldLabel: 'Email',
blankText :'请输入您的邮箱',
allowBlank:false,
name: 'email',
vtype:'email'
}, {
xtype: 'combobox',
fieldLabel: '专业班级',
allowBlank:false,
name: 'grade_class',
store: Ext.create('Ext.data.ArrayStore', {
fields: ['abbr', 'state'],
// data : Ext.example.states // from states.js
data:[['01','13计算机1班'],['02','12计算机2班'],['03','12计算机3班'],
['04','12计算机4班'],['05','12计算机5班'],['06','12计算机6班'],
['07','其他']]
}),
valueField: 'abbr',
displayField: 'state',
typeAhead: true,
queryMode: 'local',
emptyText: '例如:13计算机1班'
}, {
xtype: 'datefield',
fieldLabel: 'Date of Birth',
name: 'birthday',
allowBlank: false,
maxValue: new Date()
}
]
}], buttons: [{
text: '样例',
handler: function(){
formPanel.getForm().load({
url: 'xml-form-data.xml',
waitMsg: 'Loading...'
});
}
},
// {
// text: '提交',
// disabled: true,
// formBind: true,
// handler: function(){
// this.up('form').getForm().submit({
//// url: 'xml-form-errors.xml',
// url:'admin/userRegister',
// submitEmptyText: false,
// waitTitle:"请稍候",
// waitMsg:"正在提交表单数据,请稍候"
// })
// }
// },
{
text : '注册',
type : 'submit',
id:'register',
formBind:true,//只有表单全部校验通过 按钮才可用
disabled:true,//默认不可用
handler : function() { formPanel.getForm().submit({
//// url: 'xml-form-errors.xml',
url:'admin/userRegister',
submitEmptyText: false,
waitTitle:"请稍候",
waitMsg:"正在提交表单数据,请稍候"
});
}
},
{
text: '重置',
handler: function(){
formPanel.getForm().reset();
}
}
]
}); });

版权声明:本文为博主原创文章,未经博主允许不得转载。

EXT4.1表单提交(非AJAX)的更多相关文章

  1. Form表单提交,Ajax请求,$http请求的区别

    做过前端同学想必都避免不了要和后台server打交道.而以下这三种与后台交互的方式想必大家都不陌生. Form表单提交,Ajax请求,Angular的$http请求 以前一直搞不清楚什么时候应该用哪种 ...

  2. form表单提交与ajax消息传递

    form表单提交与ajax消息传递 1.前后端传输数据编码格式contentType: urlencoded 对应的数据格式:name=xxx&password=666 后端获取数据:requ ...

  3. form表单提交和ajax表单提交,关于移动端如何通过软键盘上的【搜索】和【前进】进行提交操作

    [文章来源]由于自己对于form研究甚少,所以一直用的都是AJAX进行提交,这次后台提出要用form提交,顺便深入研究一下:之前在做表单的时候,发现input可以通过设置不同的type属性,调用不同的 ...

  4. form表单提交转为ajax方式提交

    <form action="xxx" method="get"> //action的值是请求的url地址 <div class="f ...

  5. 学习笔记_springmvc返回值、数据写到页面、表单提交、ajax、重定向

    数据写到页面 后台往前台传数据 TestController添加 /** * 方法的返回值采用ModelAndView, new ModelAndView("index", map ...

  6. form表单提交和ajax提交的区别

    form表单是整个页面跳到服务器的地址然后提交数据: ajax是往这个地址post数据 <form style="padding:0px;margin:0px;" targe ...

  7. springmvc返回值、数据写到页面、表单提交、ajax、重定向

    实验是在前一篇文章的项目上做的: 数据写到页面 后台往前台传数据 TestController添加 /** * 方法的返回值采用ModelAndView, new ModelAndView(" ...

  8. layui表单提交与ajax访问webapi

    啊啊啊啊 这个东西实在很蛋疼啊 每次访问webapi就很老火 这里就一下  以后忘记的话就来查阅 不多说 直接开始 首先html页面 新建一个基于layui的form表单页面LayuiForm.csh ...

  9. LayUI表单提交不走ajax原因

    在使用layui的时候.遇到一个问题.提交表单,没有走ajax,直接提交了表单页面. 原因是因为JQuery未引入 解决办法.引入JQuery或者使用layui自带Jquery var $ = lay ...

随机推荐

  1. 浅淡 RxJS WebSocket

    const open$ = new Subject(); const ws = webSocket({ url: 'wss://echo.websocket.org', openObserver: o ...

  2. vim插件管理 - vim-plug

    vim-plug是一款轻量的vim插件管理工具. GitHub:https://github.com/junegunn/vim-plug 插件的安装 unix curl -fLo ~/.vim/aut ...

  3. 快速提高谷歌浏览器(Chrome)自带下载器的网速

    之前每次下载东西都是复制好下载链接到迅雷中下载,会提高成倍网速,但是时间一长,感觉不方便,废话不多说,上干货~ 由于中国防火墙(GFW)的强大,在线下载Google浏览器的时候速度非常慢,如果只是单独 ...

  4. redis必会

    1.NosqL 非关系型数据库,里面包含Redis和MondoDB2.为什么会用到关系型数据库?因为当数据量太多,访问人数过多的时候,在访问关系型数据库时会到硬盘里进行读写过多 这样就会导致访问速度很 ...

  5. 基于STM32F103ZET6 HC_SR501人体红外感应

    这是最后的实验现象,有人走过会一直输出有人,离开范围时则输出没人 开发板 PZ6086L ,HC_SR501模块 这是HC_SR501的示意图,,VCC和GND不再多做介绍,5V供电就行, OUT接口 ...

  6. go学习之文件读取问题(需更新)

    go学习之文件读取问题(需更新) 一,问题: 今天做一个GO广度迷宫问题时,出现了一个奇怪的问题. 就是通过fmt.Fscanf()读取文件时,每行末尾多出一个0. 二,问题代码: 1,输入文件maz ...

  7. Xilinx与modelsim的仿真联调

    关于Xilinx与modelsim的仿真联调,尤其是仿真环境的搭建,网上的信息都比较零散,我当初在联调的时候遇到比较多的问题,也是折腾了两天才弄好,下面的步骤我总结得非常详细,可以帮助大家少走弯路. ...

  8. 20155229实验二 《Java面向对象程序设计》实验报告

    20155229实验二 <Java面向对象程序设计>实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 ...

  9. 【转】odoo学习之:API整合文档

    Odoo8.0新API文档 一.新API概述 在8中,api接口分为traditaional style和record style,traditional style指的就是我们在7中使用的类型,de ...

  10. IDEA 运行报错 failed to create a child event loop

    背景 在IDEA中写了测试代码,但是运行的时候一直提示 java.lang.IllegalStateException: failed to create a child event loop ... ...