【发布时间】:2012-07-15 00:38:55
【问题描述】:
设置:
我有一个数据表,它的每一行都是可点击的。单击一行时,会进行一个 ajax 调用,该调用会返回一些数据。有时,ajax 调用需要一些时间,具体取决于返回的数据量。一切正常。
问题:
当快速单击行时会出现问题,一个接一个。简而言之,在上一个 ajax 调用返回之前,如果单击该行(即进行了新的 ajax 调用),我会收到错误消息。
Uncaught TypeError: Property 'callback' of object [object Window] is not a function
(ajax调用返回一个JSONP数据)
看起来 ajax 调用以某种方式混合在一起(?),但我不确定这一点。谁能告诉我为什么会这样?
如果需要更多信息来澄清问题,请告诉我。
谢谢
编辑 1:
这里是一些 ajax 代码:
$.ajax({
type: "GET",
url: 'http://' + myserver + ':8080/someurl/' + my_param,
contentType: "application/json",
dataType: "jsonp",
jsonpCallback: 'callback',
success: function(data) {
// Inside here, I am doing some Datatables stuff.
var myTable = $('#my_table').dataTable( {
"bJQueryUI" : true,
"bSort" : false,
"bFilter" : false,
"bPaginate": true,
"bProcessing": true,
"bScrollCollapse": true,
"bInfo": false,
"bDestroy": true,
"aaData": samples,
"sEmptyTable": "No sample listings avaiable",
"iDisplayLength": number,
"bLengthChange": false,
"bAutoWidth": false,
.
.
.
}
编辑 2:
这是为callback 分配其名称的类。如果默认回调为空,则它分配一个默认值“回调”。但看起来默认回调总是为空,因此它总是分配“回调”。
public class MappingJacksonJsonpConverter extends MappingJacksonHttpMessageConverter {
@Override
protected void writeInternal(Object object, HttpOutputMessage outputMessage) throws IOException,
HttpMessageNotWritableException {
JsonEncoding encoding = getJsonEncoding(outputMessage.getHeaders().getContentType());
JsonGenerator jsonGenerator = this.getObjectMapper()
.getJsonFactory()
.createJsonGenerator(outputMessage.getBody(), encoding);
try {
String jsonPadding = "callback";
if (object instanceof JsonObject) {
String jsonCallback = ((JsonObject) object).getJsonCallback();
if (jsonCallback != null) {
jsonPadding = jsonCallback;
}
}
jsonGenerator.writeRaw(jsonPadding);
jsonGenerator.writeRaw("(");
this.getObjectMapper().writeValue(jsonGenerator, object);
jsonGenerator.writeRaw(")");
jsonGenerator.flush();
} catch (JsonProcessingException ex) {
throw new HttpMessageNotWritableException("Could not write JSON: " + ex.getMessage(), ex);
}
}
}
上面的类在mvc-servlet.xml中被引用如下:
<mvc:message-converters>
<bean
class="citygrid.feedmanager.web.converter.MappingJacksonJsonpConverter">
<property name="supportedMediaTypes">
<list>
<value>application/x-javascript</value>
</list>
</property>
</bean>
</mvc:message-converters>
【问题讨论】:
-
使用同步ajax请求Here
-
@AlexBall:正如我在问题中提到的,我正在返回不支持同步调用的 JSONP 数据(跨域调用)。 api.jquery.com/jQuery.ajax
-
您使用什么来执行 AJAX 查询?你能粘贴你的ajax代码吗?
-
如果删除 jsonpCallback: 'callback' 参数会怎样?所有回调都试图使用相同的回调函数名称,那么问题出在哪里?使用生成的名称也许可以避免这种情况?
-
async:false不适用于 JSONP。它也与服务器端无关。 Chris 是对的:问题在于所有 JSONP 请求都有相同的回调。 JQuery 删除 JSONP 返回后的回调。这就是为什么如果你快速触发两个 JSONP,第二个会尝试触发undefined回调导致异常。