基本的に、私が達成しようとしているのは、不透明な黄色の 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 の世界を理解するために、お時間とご協力をいただきありがとうございます。