gpt4 book ai didi

javascript - JS 和 CSS 中的内容 slider

转载 作者:行者123 更新时间:2023-11-28 13:34:17 26 4
gpt4 key购买 nike

本质上,我想要完成的是制作一个内容 slider ,该 slider 具有不透明的黄色 div,它在过渡图像(向上状态)上滑动,然后以灰色(向下状态)向下滑动到图像底部约 100 像素).这些向下状态应充当幻灯片选择器,单击时会展开到向上状态和相关图像。

我已经尝试使用多种内容和幻灯片构建来实现这一点,但它们都无法真正让我产生效果。 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 事件。我不知道如何让这些动画不隐藏内容而是动画到上述向下状态高度。

在这方面的任何帮助都会很棒。对整个内容 slider 解决方案的任何帮助都将是救命稻草!

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

最佳答案

我认为您正在寻找动画功能而不是像这样的 slideUp...

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

http://api.jquery.com/animate/

关于javascript - JS 和 CSS 中的内容 slider ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13182701/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com