在不运行browsersync时通过jQuery更改背景图像的麻烦



我有一个滑块,可以通过更改背景图像的位置来工作。我也使用浏览器。虽然browsersync运行,但滑块效果很好,虽然效果不佳 - 所有动画都在投入,但根本不会出现。滑坡的背景图像。我做错了什么?P.S.另外,我使用背景词脚本 - 它允许设置一些参数。

  1. 看正确:https://gyazo.com/2185ae332bac4b1da1bd4f24f2fcd9bfe5a

  2. 看不正确:https://gyazo.com/681a28e927ef537f1f4f4f4f4f034faeb56b56b0d

html:

    <!DOCTYPE html>
<html>
<head>
    <title>Slider</title>
    <meta charset="utf-8">
    <link rel="stylesheet" type="text/css" href="styles/reset.css">
    <link rel="stylesheet" type="text/css" href="styles/main.css">
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
    <script src="js/backgroundPosition.js"></script>
    <script src="js/slider.js"></script>
    <link href="https://fonts.googleapis.com/css?family=Open+Sans" rel="stylesheet"> 
</head>
<body>
    <div class="slider">
        <div class="upside">
            <div class="slide">
                <div class="wheel"></div>
            </div>
        </div>
    </div>
    <div class="next"></div>
</body>
</html>

CSS:

body{
    height: 100%;
    width: 100%;
}
.slider, .upside, .slide{
    height: 650px;
    width: 1200px;
    margin: 0 auto;
    border-radius: 15px;
}
.slider{
    margin: 50px auto;
    background: url(../img/bg.jpg) no-repeat center;
    overflow: hidden;
}
.upside{
    background-image: url(../img/upside.png);
    background-repeat: no-repeat;
    background-position: 0px -800px;
}
.slide{
    background-image: url(../img/sl_1.jpg);
    background-repeat: no-repeat;
}
@keyframes rt{
    100%{
        transform: rotate(360deg);
    }
}
.wheel{
    height: 640px;
    width: 180px;
    background-image: url(../img/wheel.png);
    background-repeat: no-repeat;
    background-position: left center;
    position: relative;
    margin: 0px 0 0 -180px;
    animation: rt 6s linear infinite
}
.next{  
    height: 120px;
    width: 120px;
    margin: 0px auto;
    font-family: 'Open Sans', sans-serif;
    color: white;
    font-size: 30px;
    text-align: center;
    line-height: 120px;
    vertical-align: middle;
    text-transform: uppercase;
    background:url(../img/next.png) no-repeat;
    border-radius: 50%;
    opacity: .55;
}

JS:

$(function(){
    var btn = $(".next"),
        wheel = $(".wheel"),
        upside = $(".upside"),
        slide = $(".slide"),
        cur_slide = 1;
    var nextSlide = function(){
        btn.off();
        cur_slide++;
        if(cur_slide===4){cur_slide=1;}
        var i1 = 0;//upside bottom point
        var i2 = 650;//slide bottom point
        wheel.animate({
            margin: "0px 0 0 -105px"
        },800,
            function(){
                slide.animate({
                    backgroundPosition:("-1200 0")
                },1000,
                    function(){
                        upside.animate({
                            backgroundPosition:("0 0")
                        },1200,
                            function(){
                                slide.css('background-image',"url(../img/sl_"+cur_slide+".jpg)");
                                var up = setInterval(function(){
                                    upside.css("background-position","0 "+i1+"px");
                                    slide.css("background-position","0 "+i2+"px");
                                    if (i2===0) {
                                        clearInterval(up);
                                        upside.css("background-position","0 -800px");
                                        wheel.animate({
                                            margin: "0px 0 0 -180px"
                                        },800,
                                            function(){
                                                btn.click(nextSlide);
                                            })
                                    }
                                    i1--;
                                    i2--;
                                },2);
                            })          
                    })
            })
    }
    btn.click(nextSlide);
})

这是backgroundPosition.js的代码(不知道您需要它是否需要它)

(function($) {
 $.extend($.fx.step,{
 backgroundPosition: function(fx) {
 if (fx.pos === 0 && typeof fx.end == 'string') {
 var start = $.css(fx.elem,'backgroundPosition');
 start = toArray(start);
 fx.start = [start[0],start[2]];
 var end = toArray(fx.end);
 fx.end = [end[0],end[2]];
 fx.unit = [end[1],end[3]];
 }
 var nowPosX = [];
 nowPosX[0] = ((fx.end[0] - fx.start[0]) * fx.pos) + fx.start[0] + fx.unit[0];
 nowPosX[1] = ((fx.end[1] - fx.start[1]) * fx.pos) + fx.start[1] + fx.unit[1];
 fx.elem.style.backgroundPosition = nowPosX[0]+' '+nowPosX[1];
function toArray(strg){
 strg = strg.replace(/left|top/g,'0px');
 strg = strg.replace(/right|bottom/g,'100%');
 strg = strg.replace(/([0-9.]+)(s|)|$)/g,"$1px$2");
 var res = strg.match(/(-?[0-9.]+)(px|%|em|pt)s(-?[0-9.]+)(px|%|em|pt)/);
 return [parseFloat(res[1],10),res[2],parseFloat(res[3],10),res[4]];
 }
 }
 });
})(jQuery);

好吧,如果有人会遇到同样的问题,我会发布此解决方案:我们必须更改此问题:

slide.css('background-image',"url(../img/sl_"+cur_slide+".jpg)");

slide.css('background-image',"url(img/sl_"+cur_slide+".jpg)");

最新更新