0

这里的语法问题,因为代码工作正常。我有一个 for 循环和一个必须在其中运行的内联函数(aQuery 回调)。

  for (i=1;i <= 5;i++)  
            {
            twitter[i] = $(this).find('twitter' + i).text();
            //$('<div class="twitter[i]"></div>').html(twitter[i]).appendTo('#link_'+i);
            $('.twitter[i]').html(twitter[i]).appendTo('#link_'+i);

            // grab from twitter
            $.getJSON('http://api.twitter.com/1/users/show.json?screen_name='+twitter[i]+'&callback=?', 

            function (data)     
                    {
                          for (j=1;j <= 5; j++)     {
                          twit_count[j] = data['followers_count'].toString();
                          twit_count[j] = add_commas(twit_count[j]);
                          $('#twitter_count'+j).html(twit_count[j]);
                          }
                    }); 
             }

如果 i=3 我希望 j 在函数中是相同的值。

问题是每个 i 循环 j 循环运行五次。

将 i 作为参数传递

 function (data, i)

不起作用,一些方向将不胜感激。

谢谢,

4

2 回答 2

0

大家好,只是为了回答我自己的问题。

我想要每页的 Facebook/Twitter 关注者列表。

var f_page = ["TheHouseofMarley, Another FB ID, Another FB ID, Another FB ID"];

    for(var i=0; i < 1; i++) 
                    {
                        retrieveData(f_page[i]);
                    }

    function retrieveData(teamName) {

    var baseURL = 'http://graph.facebook.com/';
    $.getJSON(baseURL+teamName+"&callback=?", function(data) {
    $('#FBlikes').append(teamname ":" data.likes)
        });
    };

然后在 <body>

<span id='FBlikes'></span> 
于 2012-06-27T11:46:57.230 回答
0

不是 100% 确定你想要什么,但如果你想让回调函数只做一组计数器,它不应该有一个循环。

要让回调中的 j 的值与 i 相同,您必须编写一个函数来返回回调函数,并将所需的值作为参数传递给外部函数。

$.getJSON(url, ( function(j) { 
      return function(data) { 
          twit_count[j] = data['followers_count'].toString();
          twit_count[j] = add_commas(twit_count[j]);
        $('#twitter_count'+j).html(twit_count[j]);
      }
   } )(i) )

在这里查看我的答案以获得更多解释。

于 2012-06-06T09:53:48.890 回答