javascript - 一页上有多个 slider

标签 javascript jquery slider

好吧,我用 javascript 和 Jquery 构建了一个 slider (在你们的帮助下),但现在我想在一页上有多个 slider 。虽然只使用一种 JavaScript。但是... slider 的宽度(或项目数量)可以不同:由于 css 宽度, slider 的名称也不同。

那么我如何使用 1 个 JavaScript 来控制不同的 slider

这是我的代码:

HTML

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
 <script src="http://code.jquery.com/jquery-latest.js"></script>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Untitled Document</title>
<style type="text/css">
#temp{
height: 300px;
}

#container{
    width: 500px;
    height: 150px;
    background:#CDFAA8;
    overflow:hidden;
    position:absolute;
    left: 13px;
    }

#slider{
    width: 800px;
    height: 150px;
    background:#063;
    position:absolute;
    left: 0px;
}

#block1{
    width: 100px;
    height: 150px;
    background:#067;
    float: left;
}

#block2{
    width: 100px;
    height: 150px;
    background:#079;
    float: left;
}

#move_right{
    height: 150px;
    width: 20px;
    background: #3f3f3f;
    position: absolute;
    right:0px;
    z-index: 200;
    opacity: 0.2;
}

#move_left{
    height: 150px;
    width: 20px;
    background: #3f3f3f;
    position: absolute;
    left:0px;
    z-index: 200;
    opacity: 0.2;
}​
</style>
</head>

<body>
<div id="temp">
<div id="container">
    <div id="move_left"><button id="right">&laquo;</button></div><div id="move_right"><br><br><button id="left">&raquo;</button></div>
<div id="slider">

    <div id="block1">1</div>    
    <div id="block2">2</div>
    <div id="block1">3</div>    
    <div id="block2">4</div> 
    <div id="block1">5</div>    
    <div id="block2">6</div>
    <div id="block1">7</div>    
    <div id="block2">8</div>


</div>
</div>
</div>


<div id="slider">

    <div id="block1">1</div>    
    <div id="block2">2</div>
    <div id="block1">3</div>    
    <div id="block2">4</div> 
    <div id="block1">5</div>    
    <div id="block2">6</div>
    <div id="block1">7</div>    
    <div id="block2">8</div>


</div>
</div>
</div>

JavaScript

(function($) {
    var slider = $('#slider'),
        step = 500,
        left = parseInt(slider.css('left'), 10),
        max = $('#container').width() - slider.width(),
        min = 0;

    $("#left").click(function() {
        if (left > max) {
            var newLeft = left - step;
            left = (newLeft>max) ? newLeft : max;
            $("#slider").animate({
                "left": left + 'px'
            }, "slow");
        }
    });

    $("#right").click(function() {
        if (left < 0) {
            var newLeft = left + step;
            left = (newLeft<min) ? newLeft : min;
            slider.animate({
                "left": left + 'px'
            }, "slow");
        }
    });
})(jQuery);

最佳答案

这应该没问题:

(function($) {
    $('#temp #container').each(function(){
        var slider = $(this).find('#slider'),
        parent = $(this),
        step = 500,
        left = parseInt(slider.css('left'), 10),
        max = parent.width() - slider.width(),
        min = 0;

    parent.find("#left").click(function() {
        if (left > max) {
            var newLeft = left - step;
            left = (newLeft>max) ? newLeft : max;
            slider.animate({
                "left": left + 'px'
            }, "slow");
        }
    });

    parent.find("#right").click(function() {
        if (left < 0) {
            var newLeft = left + step;
            left = (newLeft<min) ? newLeft : min;
            slider.animate({
                "left": left + 'px'
            }, "slow");
        }
    });
});
})(jQuery);​

FIDDLE

关于javascript - 一页上有多个 slider ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9658840/

相关文章:

javascript - 使用 CarouFredSel 的 slider

javascript - bxslider:在 div 之外显示一半图像

javascript - Wordpress 3.8.3 自定义主题

javascript - 使用 javascripting DOM 脚本隐藏 div,具体取决于单选按钮的总和

jquery - 将 json 数组发送到 ashx 处理程序

jquery - 如何将网格从一个网格器拖动到另一个网格器?

jquery - 使用 JSON 时 jQuery 中 if 语句的说明

python - 如何在 Pygame 中插入 slider ?

javascript - 如何使用 Ramda.js 映射对象值并仅获取第一个元素?

javascript - 向列表中添加相同项目的次数过多