ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

JavaScript:将更改的参数传递给回调

2019-12-10 00:35:18  阅读:222  来源: 互联网

标签:loops callback anonymous-function javascript


现在,这是一个有趣的问题.我有一个对象数组,如下所示:

objRequests = [
   {
      url: "/cgi-bin/script1.cgi",
      dest: "#div1"
   },
   {
      url: "/cgi-bin/script1.cgi",
      dest: "#div2"
   }
];

现在,我遍历这些对象以使用jQuery的$.getJSON()方法在特定地址从服务器加载一些信息,并且在通过回调函数进行了一些花哨的处理之后,需要将HTML放入其ID是通过“目标”指定的div中. .

通常,如果我需要指定额外的数据以进入回调,则可以使用匿名函数,这样就可以了.这里的问题在于,目的地的变量指针似乎保持不变,因此,在每个回调触发时,目的地始终等于“#div2”.

我尝试了以下方法:

for (var loop = 0; loop < objRequest.length; loop++)
{
    var exec = new function(objResponse)
    {
       processResponse(objResponse, objRequest[loop].dest);
    }

    exec.dest == objRequest[loop].dest;

    $.getJSON(objConfig.strTicketScript, exec);
}

以及

for (var loop = 0; loop < objRequest.length; loop++)
{
    var destination = objRequest[loop].dest;

    var exec = new function(objResponse)
    {
       processResponse(objResponse, destination);
    }

    exec.dest == objRequest[loop].dest;

    $.getJSON(objConfig.strTicketScript, exec);
}

但由于某些原因,Firefox似乎仍未在匿名函数中创建单个数据.有没有办法在每次迭代中获得对数据的唯一引用?

解决方法:

您将需要进行关闭:

var exec = (function(dest){
  return function(objResponse) {
     processResponse(objResponse, dest);
  }
 })(objRequest[loop].dest);

标签:loops,callback,anonymous-function,javascript
来源: https://codeday.me/bug/20191210/2098218.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有