Ext.Ajax.request在2.x是异步请求的,这样话在当前请求没有完成之前就不能在它的外部使用它的返回值,在下面这个表单验证中如果不是同步请求的话就有问题了,如:
var text = new Ext.form.TextField({
fieldLabel : '名称',
height : 23,
width : 400,
id : 'flowName',
name : 'flowName',
allowBlank : false,
blankText : '名称不能为空',
validateOnBlur : true,
validationEvent : true,
validator : function() {
var resultValue;
Ext.Ajax.request({
url : '',
sync:true,
params : {
name : text.getValue()
},
success : function(response, options) {
var responseArray = Ext.util.JSON.decode(response.responseText);
resultValue=responseArray.resultValue;
}
});
if (resultValue!=null && resultValue!="") {
text.invalidText = "该名称己经存在,请重新输入!";
return false;
} else {
return true;
}
},
anchor : '95%'
});
解决办法是:
首先从http://code.google.com/p/ext-basex/下载ext-basex 脚本文件,解压后按照说明readme文件的方法引用EXT库和ext-basex,
附件中已经挂了包含ext-basex.js的rar。我将其放到了和ext-base.js同一目录,下面是引用库的代码。
<head>
<link rel="stylesheet" type="text/css" href="scripts/ext/resources/css/ext-all.css" />
<script type="text/javascript" src="scripts/ext/adapter/ext/ext-base.js"></script>
<script type="text/javascript" src="scripts/ext/adapter/ext/ext-basex.js"></script>
<script type="text/javascript" src="scripts/ext/ext-all.js"></script>
</head>
然后使用Ext.Ajax.request方法,添加 async: false, //ASYNC 是否异步( TRUE 异步 , FALSE 同步),其他参数不变。
Ext.Ajax.request({
url: "StreamingProxy.ashx",
method: "GET",
async: false, //ASYNC 是否异步( TRUE 异步 , FALSE 同步)
params: { //将真正的页面(服务)url参数传递到代理页面
u: url,
m: "GET",
t: ""
},
success: function(response, opts) {
}, //请求成功的回调函数
failure: function() { alert("获取目录请求失败!"); } // 请求失败的回调函数
});
分享到:
相关推荐
标题提到的"ext-basex.js进行Ext.Ajax.request同步请求 FF无法正常"问题,涉及到浏览器兼容性和异步/同步请求的理解。 `Ext.Ajax.request`是ExtJS中的一个方法,用于发起Ajax(异步JavaScript和XML)请求。它可以...
在标题提到的"同步请求包"问题中,EXTJS默认情况下,`Ext.Ajax.request`是异步执行的,但有时我们可能需要同步请求,例如在某些数据初始化场景。要实现同步请求,需要设置配置项`async: false`: ```javascript Ext...
ExtJs提供了Ext.Ajax.request方法来进行Ajax请求,但默认情况下,该方法不支持waitMsg属性,不像fp.form.submit方法提供了waitTitle和waitMsg属性来实现等待提示。为了解决这一限制,我们可以采用Ext.MessageBox的...
标题中提到的"extjs ajax同步请求所需js"是指ExtJS框架中用于执行同步Ajax请求的相关JavaScript代码。在ExtJS中,Ajax请求通常通过`Ext.Ajax`对象来实现。与传统的异步请求不同,同步请求会阻塞浏览器,直到请求完成...
如果需要同步请求,可以在`request`方法中设置`async: false`。 6. **处理错误:** 除了`failure`回调外,还可以使用`Ext.Ajax.onError`全局监听器来捕获所有Ajax请求的错误。 7. **取消请求:** 如果需要取消正在...
### ExtJS 3.0 AJAX 同步请求详解 #### 一、引言 ExtJS 是一款基于 JavaScript 的开源框架,用于构建现代化的 Web 应用。它提供了丰富的 UI 组件以及强大的数据处理能力,使得开发者能够快速地开发出高质量的企业...
2. 在 validator 函数中,使用 Ext.Ajax.request 方法发送 AJAX 请求,检测用户名是否已经存在于数据库中。 3. 在服务器端,使用数据库查询来检测用户名是否已经存在于数据库中。 4. 在客户端,使用 validator 函数...
EXT的Ajax功能还支持配置各种选项,如设置请求头、超时时间、同步/异步请求、数据编码方式等。例如,你可以设定请求头来添加自定义的HTTP头部信息: ```javascript headers: { 'Content-Type': 'application/json' ...
`Ext.Ajax.request()`方法是进行Ajax请求的核心函数,它接受一系列参数,包括URL、方法(GET或POST)、请求数据、回调函数等。同步与异步的控制则通过`async`参数来决定。默认情况下,`async`设置为`true`,意味着...
但本文讨论的是同步请求,在Extjs中,同步请求应该使用Ext.lib.Ajax.getConnectionObject().conn来获取原生的xmlHttpRequest对象进行操作。 在进行POST请求时,可以通过conn.send方法发送参数。但是,在尝试通过...
在ExtJS中,可以通过`Ext.Ajax.request`方法来发送Ajax请求,该方法允许我们配置请求类型(如POST或GET)、URL地址以及回调函数等参数。当请求成功或失败时,可以指定相应的回调函数来进行处理。 #### 四、代码分析...
5. **异步与同步请求**: - 默认情况下,Ajax请求是异步的,这意味着浏览器不会等待响应,而是继续执行其他代码。如果需要等待响应,可以设置`async`为`false`。 6. **缓存控制**: - Ajax请求可能会受到浏览器...
通过上述方法,我们可以有效地解决在使用ExtJS进行Ajax同步请求时,中文参数出现乱码的问题。关键是保证前后端编码的一致性,以及正确地使用编码与解码函数。此外,还可以考虑在服务器端配置文件中设置统一的字符集...
Ext.Ajax.request({ url: 'your-url', method: 'GET', success: function(response) { var result = Ext.decode(response.responseText); // 处理结果 }, failure: function(response) { // 处理失败情况 ...
你可以使用`Ext.Ajax.request`方法发送异步请求,或者配置`Ext.data.Store`以自动加载和保存数据。 例如,使用`Ext.Ajax.request`获取数据: ```javascript Ext.Ajax.request({ url: 'your/api/url', method: '...
`Ext.Ajax.request()`方法类似于jQuery的`$.ajax()`,可以定制各种请求参数。此外,它还提供了异步操作的便利性,如`Ext.data.Store`的自动加载和同步。 4. **MooTools**:MooTools的Ajax模块提供了`Request`类,...
如果希望同步请求,可将其设置为false。 - `timeout`可以设置请求超时时间。 - `jsonData`或`xmlData`可以用来直接传递JSON或XML数据,避免手动编码。 - `useDefaultXhrHeader`控制是否发送默认的`X-Requested-...
2. **Ajax提交表单**:当表单需要异步提交时,可以利用`Ext.Ajax.request`方法。这个方法接受一个配置对象,其中包含了URL、方法(GET或POST)、数据、成功和失败的回调函数等参数。在本例中,你可能将表单的提交...