- Ext.Ajax.request({
- url:'findbyid.action',
- params:{
- id:cell.getId()
- },
- success: function(resp,opts) {
- var respText = Ext.util.JSON.decode(resp.responseText);
- name=respText.name;
- oid=respText.id;
- findbyid(graph,cell,oid,name);
- //Ext.Msg.alert('错误', respText.name+"====="+respText.id);
- },
- failure: function(resp,opts) {
- var respText = Ext.util.JSON.decode(resp.responseText);
- Ext.Msg.alert('错误', respText.error);
- }
- })
在Ext开发过程中,基本上时刻需要用到异步请求,那么这个请求到底是怎么执行的呢,我们接下来来探讨下
首先:Ext.Ajax类继承了Ext.data.Connection,为Ajax的请求提供了最大灵活性的操作方式
再简单请求基础上我们加上一个使用的
说明的是这种请求通常都是放在触发某个事件的处理方法中的
url:就是我们要请求的路径
params:里面的参数用逗号隔开,就是我们要发出请求带的参数
success:是服务器处理成功返回
failure:是服务器处理失败返回
重点讲的就是如何处理返回值信息,我们的resp这个参数就显得非常重要了
resp是Ext构造的一个返回结果对象,如服务器端返回“this is a test!”(可以通过throw new Exception("this is a test!")简单实现)。那么返回将是
如下内容:
- <span style="font-size: medium;">tId.1
- status.200
- statusText.OK
- getResponseHeader.[object Object]
- getAllResponseHeaders.Server: Apache-Coyote/1.1
- Content-Type: text/html;charset=GBK
- Content-Language: zh-CN
- Content-Length: 108
- Date: Wed, 31 Oct 2007 12:51:23 GMT
- responseText.
- <html>
- <head>
- <title>错误</title>
- </head>
- <body>
- <h1>错误:this is a test!</h1>
- </body>
- </html>
- responseXML.
- argument.undefined</span>
从上面结果可以看出来,最开始是一些状态属性,我们也不常用,不管他。里面真正常用的是responseText与responseXML两个属性,那么这里面的responseText内容又被Ext用html包装了,但使用Ext.MessageBox展示出来正合适;reponseXML将在服务器端返回“text/xml”类型时使用。若服务器端返回是“text/json”类型时,客户端需要使用obj= Ext.util.JSON.decode(result.responseText);进行构造json对象,然后就可以正常使用了
具体操作返回值 我们用JSON就这么写
ServletActionContext.getResponse().setContentType("text/json; charset=utf-8");
ServletActionContext.getResponse().getWriter().write("{success:true,info:'更新信息成功',name:'" + oo.getName() + "',id:'" + id + "'}");
显然我这里返回的是JSON的值了(记住里面的属性值一定要加单引号)
var respText = Ext.util.JSON.decode(resp.responseText);
这个就可获得返回结果对象,要使用属性的话respText.id等都可直接用了
说到这里如果还想对这里面其他配置感兴趣的话可以参考下面的语句
(可选项)发送请求的url,默认为配置的url。 若为函数类型那么其作用域将由配置项scope所指定。默认为配置好的URL。 The URL to which to send the request, or a function to call which returns a URL string. The scope of the function is specified by the scope option. Defaults to configured URL.
一包含属性的对象(这些属性被用作request的参数)或一个编码后的url字串或一个能调用其中任一一属性的函数。 若为函数类型那么其作用域将由配置项scope所指定。 An object containing properties which are used as parameters to the request, a url encoded string or a function to call to get either. The scope of the function is specified by the scope option.
该请求所用的http方面,默认值为配置的方法,或者当没有方法被配置时,如果没有发送参数时用get,有参数时用post。 The HTTP method to use for the request. Defaults to the configured method, or if no method was configured, "GET" if no parameters are being sent, and "POST" if parameters are being sent. Note that the method name is case-sensitive and should be all caps.
该方法被调用时附上返回的http response对象。不管成功还是失败,该回调函数都将被调用,该函数中传入了如下参数: The function to be called upon receipt of the HTTP response. The callback is called regardless of success or failure and is passed the following parameters:
-
options : Object
>请求所调用的参数。The parameter to the request call.
-
success : Boolean
请求成功则为true。True if the request succeeded.
-
response : Object
包含了返回数据的xhr对象。The XMLHttpRequest object containing the response data. Seehttp://www.w3.org/TR/XMLHttpRequest/ for details about accessing elements of the response.
该函数被调用取决于请求是否成功。该回调函数被传入如下参数: The function to be called upon success of the request. The callback is passed the following parameters:
-
response : Object
包含数据的xhr对象。The XMLHttpRequest object containing the response data.
-
options : Object
请求所调用的参数。The parameter to the request call.
该函数被调用取决于请求失败。该回调函数被传入如下参数: The function to be called upon failure of the request. The callback is passed the following parameters:
-
response : Object
包含数据的xhr对象。 The XMLHttpRequest object containing the response data.
-
options : Object
请求所调用的参数。 The parameter to the request call.
回调函数的作用域:回调函数"this"对象指针。默认值为浏览器窗口。 The scope in which to execute the callbacks: The "this" object for the callback function. If the url, or params options were specified as functions from which to draw values, then this also serves as the scope for those function calls. Defaults to the browser window.
用来压入参数的一个<form>元素或<form>的标识。 The <form> Element or the id of the <form> to pull parameters from.
如果该form对象是上传form,为true(通常情况下会自动探测)
为请求所加的请求头。 Request headers to set for the request.
用于发送的xml document。注意:它将会被用来在发送数据中代替参数任务参数将会被追加在url中。 XML document to use for the post. Note: This will be used instead of params for the post data. Any params will be appended to the URL.
JSON data to use as the post. Note: This will be used instead of params for the post data. Any params will be appended to the URL.
设置为True,则添加一个独一无二的cache-buster参数来获取请求。 True to add a unique cache-buster param to GET requests
发表评论
-
修改extjs4默认字体
2014-10-13 16:02 387.x-btn-default-small .x-btn ... -
ExtJs默认的字体大小改变的几种方法
2014-10-13 10:11 5991、 只需把ext-all.css样式文件中的所有11px换 ... -
Eclipse环境下配置spket中ExtJS提示
2014-08-20 14:57 471使用eclipse编写extjs时,一定会用到spket这个 ... -
extjs继承,先调用父类方法
2014-07-17 14:27 976Ext.define('Xap.core.ui.extjs. ... -
extjs4.0 Ext.Array 函数方法大全
2014-07-17 10:38 507Ext.onReady(function(){ ... -
JSDuck安装及使用
2014-07-15 10:40 1313Javascript:前端利器 之 JSDuck 目 ... -
ext 获取radiogroup的值
2013-03-07 11:46 851在grid工具栏中 this.tbar = [{ ... -
ext 上传
2013-01-28 22:23 614今天发现ext 上传带有如下特殊字符 \/:*?“< ... -
ext grid 隐藏列
2013-01-22 17:49 692如果是动态隐藏的话:grid.getColumnModel() ... -
comboboxGrid多列
2013-01-21 17:16 850未完善版,后期将贴出完善版,完善版主要是封装了grid ... -
解决Ext2.0中ComboBox执行Filter第一次无效的问题
2013-01-16 16:45 790解决Ext2.0中ComboBox执行Filter第一次无效 ... -
decode encode
2013-01-07 15:49 569Ext中有两个很重要的方法, 一个是decode,一 ... -
Ext. 用XTemplate实现多列的ComboBox
2012-12-26 18:24 768原文出处http://blog.csdn.net/wanghu ... -
Ext.form各类控件的配置及方法
2012-12-19 14:30 705Ext.form各类控件的配置及方法 1、Ext.fo ... -
ExtJs中decode与encode
2012-12-10 18:03 612出自:http://blog.163.c ...
相关推荐
ExtJS之Ext.Ajax.request用法详解.docx
ExtJS之Ext.Ajax.request用法详解.pdf
ExtJS之Ext.Ajax.request用法详解 (2).docx
ExtJS之Ext.Ajax.request用法详解 (2).pdf
标题"Ext.Ajax.request跨域"指出我们将探讨如何使用ExtJS库中的Ajax模块进行跨域请求。Ext.Ajax.request是ExtJS提供的一种发起Ajax请求的方式,它允许开发者向服务器发送异步HTTP请求。然而,由于浏览器的同源策略...
在EXTJS库中,`Ext.Ajax.request`是用于发送Ajax请求的核心方法,它支持异步和同步操作。本文将详细解析如何利用`Ext.Ajax.request`实现同步请求,并探讨其背后的原理和注意事项。 首先,我们需要理解Ajax的本质,...
这一实现过程涉及了ExtJs框架中的一些核心组件使用方法,需要开发者具备一定的ExtJs框架使用基础和JavaScript编程经验。通过上述方法,可以在不直接修改Ext.Ajax.request方法的前提下,实现一个用户友好的等待提示,...
在EXTJS框架中,`Ext.Ajax.request`是进行异步AJAX通信的核心方法,它提供了与服务器端交互的能力,支持GET、POST等多种HTTP请求方式。这篇文章将深入探讨`Ext.Ajax.request`的使用,以及在实际应用中可能遇到的小...
`Ext.Ajax.request`是ExtJS中的一个方法,用于发起Ajax(异步JavaScript和XML)请求。它可以执行GET、POST、PUT、DELETE等各种HTTP操作。在默认情况下,这些请求是异步的,这意味着它们不会阻塞页面的其他操作,而是...
在EXTJS框架中,`Ext.FormPanel`和`Ext.Ajax.request`提供了两种不同的异步提交方法,它们各自有其特点和适用场景。下面我们将详细探讨这两种方式的区别。 1. **Ext.FormPanel的异步提交** `Ext.FormPanel` 是...
Ext.Ajax.request({ url: "updateuser.aspx", params: { data: Ext.encode(record.data), // 将数据编码成字符串形式 id: record.id }, success: function() { alert(10); } }); grid.getView().refresh...
在使用`Ext.Ajax.request`方法时,设置`async`参数为`false`可以使请求变为同步。例如: ```javascript Ext.Ajax.request({ url: 'your-url', method: 'GET', async: false, // 设置为false表示同步请求 ...
1. 使用`Ext.Ajax.request`进行异步请求,服务器可以返回JSON或HTML片段。 2. `Ext.tree.TreeLoader`用于加载树形结构,服务器需返回符合`Ext.tree.TreeNode`配置要求的JSON数据。 3. `Ext.data.Store`及其子类处理...
`Ext.Ajax.request`方法是Ext.Ajax中最常用的功能,它允许开发者以配置参数的形式发送异步请求。这种方法简化了Ajax请求的过程,开发者只需提供请求URL、请求类型(默认为GET)、请求参数、回调函数等信息即可发起...
【EXTJS】Ext.AJAX与FormPanel在登录案例中的应用 EXTJS是一个强大的JavaScript库,主要用于构建富客户端Web应用程序。在EXTJS中,Ext.AJAX和Ext.FormPanel是两个核心组件,它们分别用于异步与服务器进行数据交互和...
6.3 元素常见的使用方法 6.3.1 常见的“显示/隐藏”方法 6.3.2 常见的“内容控制”方法 6.3.3 常见的“操控DOM”方法 6.3.4 常见的“尺寸大小/定位”方法 6.3.5 常见的“特效动画”方法 6.3.6 DomHelper简介 ...
在EXTJS中,`Ext.AJAX.Request`方法是进行Ajax通信的基础。其常用参数包括: - `url`: 服务器接口地址。 - `params`: 请求参数,通常为键值对字符串。 - `method`: HTTP请求方法,通常是GET或POST。 - `callback`: ...
6.3 元素常见的使用方法 6.3.1 常见的“显示/隐藏”方法 6.3.2 常见的“内容控制”方法 6.3.3 常见的“操控DOM”方法 6.3.4 常见的“尺寸大小/定位”方法 6.3.5 常见的“特效动画”方法 6.3.6 DomHelper简介 ...