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. Rabbitmq(二)

    1.安装 Rabbit MQ 是建立在强大的Erlang OTP平台上,因此安装RabbitMQ之前要先安装Erlang. erlang:http://www.erlang.org/download. ...

  2. [Doctrine Migrations] 数据库迁移组件的深入解析四:集成diff方式迁移组件

    场景及优势 熟悉Symfony框架之后,深刻感受到框架集成的ORM组件Doctrine2的强大之处,其中附带的数据迁移也十分方便.Doctrine2是使用Doctrine DBAL组件把代码里面的表结 ...

  3. 解决在 win10 下 vs2017 中创建 MFC 程序拖放文件接收不到 WM_DROPFILES 消息问题

    解决方案 这个问题是由于 win10 的安全机制搞的鬼,即使以管理员权限运行也不行,因为它会把 WM_DROPFILES 消息过滤掉,那怎么办呢?只需在窗口初始化 OnInitDialog() 里添加 ...

  4. C# 对DataTable的简单操作

    //更改列名 dt.Columns["原来的列名"].ColumnName="新的列名"; //移除列 dt.Columns.Remove("列名&q ...

  5. Oracle入门第二天(下)——单行函数

    一.概述 以下内容完整参阅,参考官方文档函数手册部分:https://docs.oracle.com/cd/E11882_01/nav/portal_5.htm 离线chm手册英文版:链接:https ...

  6. Mycp补交作业

    Mycp补交作业 代码 import java.io.; import java.lang.; import java.util.Scanner; public class MyCP { public ...

  7. 20155217 2016-2017-2《java程序设计》第一周学习总结

    20155217 2016-2017-2<java程序设计>第一周学习总结 浏览教材,根据自己的理解每章提出一个问题 java平台和java编程语言的区别? 怎样使用IDE来管理原始码与位 ...

  8. 2017-2018-1 20155232 《信息安全系统设计基础》第四周学习总结以及课上myod练习补充博客

    2017-2018-1 20155232 <信息安全系统设计基础>第四周学习总结以及课上myod练习补充博客 课上myod练习 1 参考教材第十章内容 2 用Linux IO相关系统调用编 ...

  9. XMAPP 的安装与配置

    1.XMAPP简介 1.1.XAMPP(Apache+MySQL/MariaDB+PHP+Perl)   开头的X代表X-OS,代表可以在任何常见操作系统下使用,包括Windows.Mac.Linux ...

  10. 关于第11周课堂mini dc的课堂练习

    测试代码: 码云链接 import java.util.Scanner; public class MyDCTester { public static void main(String[] args ...