3

我目前已经写了这个,但标题说有没有更好的方法来编写/优化这段代码?

var p = $('#pstrip');

$('a.Btn1').click(function() {
    p.animate({left: '0px'});
});
$('a.Btn2').click(function() {
    p.animate({left: '-730px'});
});
$('a.Btn3').click(function() {
    p.animate({left: '-1460px'});
});
$('a.Btn4').click(function() {
    p.animate({left: '-2190px'});
});
$('a.Btn5').click(function() {
    p.animate({left: '-2920px'});
});
4

4 回答 4

4

如果您只想缩短它,那么这样的事情可能会奏效。

$.each([1,2,3,4,5], function(idx, el) {
    var ix = idx;
    $('a.Btn' + el).click(function() {
        p.animate({left: (-730*ix) + 'px'});
    });
})

编辑:哎呀,参数倒退了。
编辑 2:正如 Imp 在下面指出的,我们需要确保它正确调用 - 我只是用不同的方式

于 2012-04-28T03:07:15.413 回答
2
var p = $('#pstrip');
var coords = [0, -730, -1460, -2190, -2920];

for (var i = 0; i < 5; i++)
    $('a.Btn' + (i + 1)).click((function(index) {
        return function() {
            p.animate({left: coords[index]});
        }
    })(i));

我将坐标放入数组并循环遍历a.Btn元素,以便第 (i+1) 个元素与第 i 个坐标相关联。要绑定到click事件的函数不是直接指定的,而是由立即调用的函数表达式返回。原因是如果我只是简单地写

.click(function() { p.animate({left: coords[i]}); })

那么所有回调函数都会在闭包中引用相同i的内容,这5在当时是有价值的。

于 2012-04-28T03:10:57.130 回答
2

负载效率更高一点,因为它只调用一次.click()

$("#button_container a").click(function() {
    $("#pstrip").animate({left: ($(this).attr("class").match(/Btn([0-9]+)/)[1] * -730) + "px"});
});

这有一个额外的好处,就是能够添加更多按钮而无需修改 javascript。

于 2012-04-28T03:11:11.437 回答
2

首先选择所有具有以 开头的类的锚点Btn。然后它将一个匿名函数绑定到所有这些函数,该函数确定#pstrip将移动的像素数。

$("a[class^=Btn]").on("click", function(){
  var n = -730 * ( this.className.match(/\d+/) - 1 );
  $("#pstrip").animate({ left: n + 'px' });
});

这将适用于任意数量的锚点。

演示: http: //jsbin.com/ovibun/5/edit
性能:http: //jsperf.com/five-buttons/3

在此处输入图像描述

于 2012-04-28T03:44:52.217 回答