2

我有一个链接列表。我想要做的是使用 jQuery 为每个链接附加一个函数;单击链接时,该函数将运行,并将一对图像加载到一个 div 中(img ids“img1”和“img2”)。每个链接都有“链接”类,并将加载一对不同的图像。因此,第一个链接将加载 Image 1A 和 Image 1B,第二个链接将加载 Image 2A 和 2B,依此类推。我有两个数组中的图像。

但是,它不是像我想要的那样附加调用,而是在页面停止加载后加载数组的最后两个图像。更重要的是,点击链接什么也没做!

var loadImages =
{
    init: function()
    {
        var links = $( ".link" );
        myArray1 = [ 
            "imgs/png/image1.png",
            "imgs/png/image2.png",
            "imgs/png/image3.png",
        ];
        myArray2 = [ 
            "imgs/jpg/image1.jpg",
            "imgs/jpg/image2.jpg",
            "imgs/jpg/image3.jpg",
        ];
        for ( var i = 0, ii = links.length; i < ii; i++ )
        {
            $( links[ i ] ).bind( "click", loadImages.imgLoader( myArray1[ i ],
                myArray2[ i ] ) );
        }
    },
    imgLoader: function( firstURI, secondURI )
    {
        document.getElementById( "img1" ).src = firstURI;
        document.getElementById( "img2" ).src = secondURI;
    }
};
loadImages.init();
4

2 回答 2

2

您不绑定回调函数。您执行loadImages.imgLoader并传递结果。

通常你可以只绑定一个回调函数,但由于你在回调本身中使用了一个计数器变量,你需要警惕的范围i

$(links[i]).on("click", (function(j) {
    return function() {
        loadImages.imgLoader(myArray1[j], myArray2[j]);
    }
})(i));

更好的方法是一次将事件处理程序绑定到所有链接,并在没有for循环的情况下处理图像交换:

$('.link').click(function() {
    var index = $(this).index();

    $('#img1').prop('src', myArray1[index]);
    $('#img2').prop('src', myArray2[index]);
});
于 2013-06-18T23:28:39.823 回答
0

尝试使用该.each()方法。

var loadImages = {
  init: function(){
    var myArray1 = ['imgs/png/image1.png', 'imgs/png/image2.png', 'imgs/png/image3.png'];
    var myArray2 = ['imgs/jpg/image1.jpg', 'imgs/jpg/image2.jpg','imgs/jpg/image3.jpg'];
    $('.link').each(function(i){
      $(this).click(function(){
        loadImages.imgLoader(myArray1[i], myArray2[i]);
      });
    });
  },
  imgLoader: function(firstURI, secondURI){
    $('#img1').attr('src', firstURI);
    $('#img2').attr('src', secondURI);
  }
};
loadImages.init();

此外,您应该使用关键字var,以便您的变量没有全局范围,并删除数组末尾的逗号。访问http://api.jquery.com/each/了解更多信息.each()

于 2013-06-19T00:14:08.770 回答