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. ssm多数据源的操作

    公司要求,需要使用两个数据库,一个mysql,一个oracle.所以需要配置两个数据库来进行操作. 1.首先,需要在jdbc.properties文件中将两个库的配置数据写入,不过一个写driver, ...

  2. 常用PHP方法

    个人常用的一些方法记录/** * 返回错误 * * @param int $err_no * @param string $err_msg * @param array $data * @return ...

  3. react native android模拟机调试

    模拟机调试首先要确认你的环境变量的path中是不是有adb的路径,adb一般在android的adk目录下的platform-tools下,android目录默认是在c盘user/administra ...

  4. C语言堆排序

    堆是一种类似二叉树的数据结构,分为最大堆和最小堆,最大堆得定义是当前节点必须大于左右子节点,堆中所有节点都要符合这个定义.最小堆反之.这一点不同于二叉树排序.假设有数组int a[10] = {90, ...

  5. node.js之express中app.use

    express中app.use 用法: app.use([path,] function [, function…]) 一.app.use() 在express中是怎么工作的 app.use在expr ...

  6. spark 例子groupByKey分组计算2

    spark 例子groupByKey分组计算2 例子描述: 大概意思为,统计用户使用app的次数排名 原始数据: 000041b232,张三,FC:1A:11:5C:58:34,F8:E7:1E:1E ...

  7. spark 例子groupByKey分组计算

    spark 例子groupByKey分组计算 例子描述: [分组.计算] 主要为两部分,将同类的数据分组归纳到一起,并将分组后的数据进行简单数学计算. 难点在于怎么去理解groupBy和groupBy ...

  8. 20155236 《信息安全概论》实验二(Windows系统口令破解)实验报告

    20155236 <信息安全概论>实验二(Windows系统口令破解)实验报告 北京电子科技学院(BESTI) 实验报告 课程:信息安全概论 班级:1552 姓名:范晨歌 学号:20155 ...

  9. 2017-2018-1 20155338 《信息安全系统设计基础》第5周加分项Mybash的实现

    2017-2018-1 20155338 <信息安全系统设计基础>第5周加分项Mybash的实现 使用fork,exec,wait实现mybash 一.fork函数 定义和理解:fork( ...

  10. lamp环境搭建(centos6.9+apache2.4+mysql5.7+php7.1)

    lamp环境搭建(centos6.9+apache2.4+mysql5.7+php7.1) 安装前准备:CentOS 6.9 64位 最小化安装 yum install -y make gcc gcc ...