Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/442.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript JS和CSS中的内容滑块_Javascript_Jquery_Css_Animation_Overlay - Fatal编程技术网

Javascript JS和CSS中的内容滑块

Javascript JS和CSS中的内容滑块,javascript,jquery,css,animation,overlay,Javascript,Jquery,Css,Animation,Overlay,从本质上说,我试图实现的是制作一个内容滑块,它有一个不透明的黄色div,可以在过渡图像(向上状态)上滑动,然后在图像底部以灰色(向下状态)向下滑动到大约100px。这些向下状态应充当幻灯片选择器,单击后可扩展到向上状态和相关图像 我尝试过使用一些内容和幻灯片构建来实现这一点,但没有一个真正允许我开发效果。s3Slider是我用得最成功的一款,因为它可以获得每张幻灯片的最新状态动画 以下是js:: (function($){ $.fn.s3Slider = function(vars) {

从本质上说,我试图实现的是制作一个内容滑块,它有一个不透明的黄色div,可以在过渡图像(向上状态)上滑动,然后在图像底部以灰色(向下状态)向下滑动到大约100px。这些向下状态应充当幻灯片选择器,单击后可扩展到向上状态和相关图像

我尝试过使用一些内容和幻灯片构建来实现这一点,但没有一个真正允许我开发效果。s3Slider是我用得最成功的一款,因为它可以获得每张幻灯片的最新状态动画

以下是js::

(function($){  

$.fn.s3Slider = function(vars) {       

    var element     = this;
    var timeOut     = (vars.timeOut != undefined) ? vars.timeOut : 4000;
    var current     = null;
    var timeOutFn   = null;
    var faderStat   = true;
    var mOver       = false;
    var items       = $("#" + element[0].id + "Content ." + element[0].id + "Image");
    var itemsSpan   = $("#" + element[0].id + "Content ." + element[0].id + "Image span");

    items.each(function(i) {

        $(items[i]).mouseover(function() {
           mOver = true;
        });

        $(items[i]).mouseout(function() {
            mOver   = false;
            fadeElement(true);
        });

    });

    var fadeElement = function(isMouseOut) {
        var thisTimeOut = (isMouseOut) ? (timeOut/2) : timeOut;
        thisTimeOut = (faderStat) ? 10 : thisTimeOut;
        if(items.length > 0) {
            timeOutFn = setTimeout(makeSlider, thisTimeOut);
        } else {
            console.log("Poof..");
        }
    }

    var makeSlider = function() {
        current = (current != null) ? current : items[(items.length-1)];
        var currNo      = jQuery.inArray(current, items) + 1
        currNo = (currNo == items.length) ? 0 : (currNo - 1);
        var newMargin   = $(element).width() * currNo;
        if(faderStat == true) {
            if(!mOver) {
                $(items[currNo]).fadeIn((timeOut/6), function() {
                    if($(itemsSpan[currNo]).css('bottom') == 0) {
                        $(itemsSpan[currNo]).slideUp((timeOut/6), function() {
                            faderStat = false;
                            current = items[currNo];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    } else {
                        $(itemsSpan[currNo]).slideDown((timeOut/6), function() {
                            faderStat = false;
                            current = items[currNo];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    }
                });
            }
        } else {
            if(!mOver) {
                if($(itemsSpan[currNo]).css('bottom') == 0) {
                    $(itemsSpan[currNo]).slideDown((timeOut/6), function() {
                        $(items[currNo]).fadeOut((timeOut/6), function() {
                            faderStat = true;
                            current = items[(currNo+1)];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    });
                } else {
                    $(itemsSpan[currNo]).slideUp((timeOut/6), function() {
                    $(items[currNo]).fadeOut((timeOut/6), function() {
                            faderStat = true;
                            current = items[(currNo+1)];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    });
                }
            }
        }
    }

    makeSlider();

};  

})(jQuery);  
这是一段很短的代码,我正试图修改它以获得我想要的效果。代码似乎从jquery中调用了.slideUp和.slideDown事件。我不知道如何使这些动画不隐藏内容,而是动画到前面提到的向下状态高度

在这方面有任何帮助都会很好。对整个内容滑块解决方案的任何帮助都将是一个救命稻草


感谢您的时间和帮助,帮助我了解jquery的世界。

我想您是在寻找动画功能而不是slideUp,就像这样

$someDiv.animate({top: '-=200'});

这是当前页面。感谢您的回复!但是,当我用.animate替换slideDown和slideUp时,会出现语法错误。提示?好的,解决了语法错误。现在,我将.slideUp/Down替换为.animate,现在div没有出现。。。我做了一个简单版本的动画+=200和-=200。保持代码的其余部分完好无损。思想?它们根本就没有出现吗?还是仅在动画期间或之后?取下动画,看看它们是否出现在正确的起始位置。可能是css问题。为了证明概念,在得出问题出在.animate()之前,先获得一个简单的JSFIDLE版本。