/**
 * 第一种Ajax提交方式
 * 这种方式需要直接使用ext Ajax方法进行提交
 * 使用这种方式,需要将待传递的参数进行封装
 * @return
 */
function saveUser_ajaxSubmit1() {
 Ext.Ajax.request( {
  url : 'user_save.action',
  method : 'post',
  params : {
   userName : document.getElementById('userName').value,
   password : document.getElementById('password').value
  },
  success : function(response, options) {
   var o = Ext.util.JSON.decode(response.responseText);
   alert(o.msg);
  },
  failure : function() {
  }
 });
}
/**
 * 第二种Ajax提交方式
 * 这种方式将为ext的ajax指定一个html表单
 * 使用这种方式,不需要将待传递的参数进行封装
 * 
 * @return
 */
function saveUser_ajaxSubmit2() {
 Ext.Ajax.request( {
  url : 'user_save.action',
  method : 'post',
  form : 'userForm', // 指定表单
  success : function(response, options) {
   var o = Ext.util.JSON.decode(response.responseText);
   alert(o.msg);
  },
  failure : function() {
  }
 });
}
/**
 * 第三种Ajax提交方式
 * 这种方式将为ext的自己的表单进行提交
 * 使用这种方式,需要使用ext自己的textField组件
 * 
 * @return
 */
function saveUser_ajaxSubmit3() {
 // 定义表单
 var formPanel = new Ext.FormPanel( {
  labelWidth : 75,
  frame : true,
  bodyStyle : 'padding:5px 5px 0',
  width : 350,
  defaults : {
   width : 230
  },
  defaultType : 'textfield',
  items : [ {
   fieldLabel : '用户名',
   name : 'userName',
   allowBlank : false
  }, {
   fieldLabel : '密   码',
   name : 'password'
  } ]
 });
 // 定义窗口
 var win = new Ext.Window( {
  title : '添加用户',
  layout : 'fit',
  width : 500,
  height : 300,
  closeAction : 'close',
  closable : false,
  plain : true,
  items : formPanel,
  buttons : [ {
   text : '确定',
   handler : function() {
    var form = formPanel.getForm();
    var userName = form.findField('userName').getValue().trim();
    var password = form.findField('password').getValue().trim();
    if (!userName) {
     alert('用户名不能为空');
     return;
    }
    if (!password) {
     alert('密码不能为空');
     return;
    }
    form.submit( {
     waitTitle : '请稍后...',
     waitMsg : '正在保存用户信息,请稍后...',
     url : 'user_save.action',
     method : 'post',
     success : function(form, action) {
      alert(action.result.msg);
     },
     failure : function(form, action) {
      alert(action.result.msg);
     }
    });
   }
  }, {
   text : '取消',
   handler : function() {
    win.close();
   }
  } ]
 });
 win.show();
}
/**
 * 第四种Ajax提交方式
 * 这种方式将html的表单转化为ext的表单进行异步提交
 * 使用这种方式,需要定义好html的表单
 * 
 * @return
 */
function saveUser_ajaxSubmit4() {
 new Ext.form.BasicForm('userForm').submit( {
  waitTitle : '请稍后...',
  waitMsg : '正在保存用户信息,请稍后...',
  url : 'user_save.action',
  method : 'post',
  success : function(form, action) {
   alert(action.result.msg);
  },
  failure : function(form, action) {
   alert(action.result.msg);
  }
 });
}

extJs常用的四种Ajax异步提交的更多相关文章

  1. ASP.NET MVC 网站开发总结(五)——Ajax异步提交表单之检查验证码

    首先提出一个问题:在做网站开发的时候,用到了验证码来防止恶意提交表单,那么要如何实现当验证码错误时,只是刷新一下验证码,而其它填写的信息不改变? 先说一下为什么有这个需求:以提交注册信息页面为例,一般 ...

  2. Java中常用的四种线程池

    在Java中使用线程池,可以用ThreadPoolExecutor的构造函数直接创建出线程池实例,如何使用参见之前的文章Java线程池构造参数详解.不过,在Executors类中,为我们提供了常用线程 ...

  3. iOS中常用的四种数据持久化方法简介

    iOS中常用的四种数据持久化方法简介 iOS中的数据持久化方式,基本上有以下四种:属性列表.对象归档.SQLite3和Core Data 1.属性列表涉及到的主要类:NSUserDefaults,一般 ...

  4. AJAX异步提交,浏览器总跳出下载界面

    问题: 我在写一个网页的“用户登录”部分时,要将用户名和密码传到后端验证,想在前端用了AJAX异步提交功能,将 用户名密码传到后端,然后后端返回验证结果.但AJAX写好后每次刷新网页都会跳出下载窗口, ...

  5. php表单提交 图片、音乐、视频、文字,四种类型共同提交到数据库

    这个问题一直困扰了我好几天,终于在今天让我给解决了,难以掩饰的激动. 其实在之前没有接触到这种问题,只是表单提交数据而已,再就是图片,四种类型同时提交还真是没遇到过,做了一个系统,其中有一个功能就是提 ...

  6. jQuery选取所有复选框被选中的值并用Ajax异步提交数据

    昨天和朋友做一个后台管理系统项目的时候涉及到复选框批量操作,如果用submit表单提交挺方便的,但是要实现用jQuery结合Ajax异步提交数据就有点麻烦了,因为我之前做过的项目中基本上没用Ajax来 ...

  7. Ajax异步提交登录(2)--登录使用

    http://cjp1989.iteye.com/blog/1740964 1.Ajax的原理: Ajax的原理就是:通过javascript的方式,将前台数据通过xmlhttp对象传递到后台,后台在 ...

  8. 【温故知新】——原生js中常用的四种循环方式

    一.引言 本文主要是利用一个例子,讲一下原生js中常用的四种循环方式的使用与区别: 实现效果: 在网页中弹出框输入0   网页输出“欢迎下次光临” 在网页中弹出框输入1   网页输出“查询中……” 在 ...

  9. ajax 异步 提交 含文件的表单

    1.前言 需求是使用 jquery 的 ajax 异步提交表单,当然,不是简单的数据,而是包含文件数据的表单.于是我想到了 new FormData() 的用法, 可是仍然提交失败,原来是ajax的属 ...

随机推荐

  1. 统计--VARCHAR与NVARCHAR在统计预估上的区别

    最近遇到一个问题,当查询使用到模糊查询时,由于预估返回行数过高,执行计划认为索引查找+Key Lookup的成本过高,因此采用Clustered Index Scan的方式,消耗大量逻辑IO,执行计划 ...

  2. 初识Identity并添加身份验证管理页面

    目录 初识Identity并添加身份验证管理页面 前言 什么是ASP.NET Core Identity 创建带有身份验证的WebApp 尝试运行 检查解决方案中的项目文件 发现问题 原因 解决问题 ...

  3. 剑指offer编程题Java实现——面试题7用两个栈实现队列

    题目:用两个栈实现一个队列.队列的声明如下:请实现他的两个函数appendTail和deleteHead, 分别完成在队列尾部插入节点和在队列头部删除节点的功能. package Solution; ...

  4. 【转】C#中Serializable序列化实例详解

    这篇文章主要介绍了C#中Serializable序列化,以实例形式详细讲述了系列化的技术及各种序列化方法,非常具有实用价值,需要的朋友可以参考下 本文实例讲述了C#中Serializable序列化.分 ...

  5. Android Parcelable using Kotlin

    Kotlin 有 extension 可以很方便的让类继承 Parcelable 接口. 项目中引入一个较新版本的 Kotlin 引入 Kotlin extensions classpath &quo ...

  6. C语言Socket-模拟远程CMD(客户端向服务器发送命令,服务器执行该命令)

    服务端(server) #include <stdio.h> #include <winsock2.h> #pragma comment(lib,"ws2_32.li ...

  7. 前端基础-html 字体标签,排版标签,超链接,图片标签

    主要内容: 字体标签: h1~h6.<font>.<u>.<b>.<strong><em>.<sup>.<sub> ...

  8. jQuery基础(3)- ajax

    一.jQuery的ajax 1.什么是ajax AJAX = 异步的javascript和XML(Asynchronous Javascript and XML). 简言之,在不重载整个网页的情况下, ...

  9. JavaScript对象与JSON字符串的相互转换

    JSON(JavaScript Object Notation) 是JavaScript编程语言的一个子集.正因JSON是JavaScript的一个子集,所以它可清晰的运用于此语言中. eval函数 ...

  10. Dubbo原理实现之代理接口的定义

    Dubbo有很多的实现采用了代码模式,Dubbo由代理工厂ProxyFactory对象创建代理对象. ProxyFactory接口的定义如下: @SPI("javassist") ...