javascript-jQuery在ajax全局事件中注入数据

我正在尝试在ajax请求中注入数据,但是它失败了,我也不知道为什么.我试图查看jQuery源代码,但仍然找不到为什么它不起作用,感谢任何帮助.这是代码

$('#someElement').ajaxSend(function(e, req, options) {
    options.data += (options.data.length > 0 ? '&' : '') + '__token=' + $('input#requestToken').val();
}).ajaxSuccess(function(e, req, options, data) {
    if (data.nextToken) {
        $('input#requestToken').val(data.nextToken);
        delete data.nextToken;
    }
});

响应如下所示:

{
   "response":
   {
      "code":0,
      // ...
   },
   "nextToken":"4ded26352b3d44"
}

典型的请求是,例如:

$.getJSON(url, {something:'value'}, function(data) {
   if (data.response.code != 0) {
      // handle code
   }
});

问题在于,发送的数据是“某物=值”;修改后的数据不发送.

**编辑**

当前请求数据是

something: value

并且应该是

something: value
__token: 4ded288eec1f56

在ajaxSend事件回调中,如果在修改后打印options.data的值,则该值为“ something = value& __ token = 4ded288eec1f56”,但是不会发送“ __token = 4ded288eec1f56”.为什么没有在请求中发送?

但更具体地说,如果可能的话,如何“修复”此问题?

解决方法:

我认为问题在于,当jQuery决定调用“ ajaxSend”回调时,参数已用于准备请求.因此,在该处理程序中更改它们无效.

编辑-从@mikermcneil给出答案,我不确定这是正确的.至少可以说,jQuery“ ajax”方法很复杂.他的示例页面似乎可以正常工作,这使我感到困惑,但可能应该只是帮助我认识到我对jQuery内部知识知之甚少:-)

相关文章

IE6是一个非常老旧的网页浏览器,虽然现在很少人再使用它,但...
PHP中的count()函数是用来计算数组或容器中元素的个数。这个...
使用 AJAX(Asynchronous JavaScript and XML)技术可以在不...
Ajax(Asynchronous JavaScript and XML)是一种用于改进网页...
本文将介绍如何通过AJAX下载Excel文件流。通过AJAX,我们可以...
Ajax是一种用于客户端和服务器之间的异步通信技术。通过Ajax...