创建动态 Jssor 嵌套滑块
Creating a dynamic Jssor nested slider
我正在尝试创建一个动态 jssor 嵌套滑块,它将显示 mySQL 数据库中的相册和相关图像。现在,它只适用于一张专辑,但当数据库中存在两个或更多专辑时,它无法正确显示。我对 JavaScript 和 JQuery 比较陌生。下面是我的代码。
<div id="slider1_container" style="position: relative; top: 0px; left: 0px; width: 810px; height: 600px; background: #24262e; overflow: hidden; ">
<!-- Loading Screen -->
<div u="loading" style="position: absolute; top: 0px; left: 0px;">
<div style="filter: alpha(opacity=70); opacity:0.7; position: absolute; display: block;
background-color: #000; top: 0px; left: 0px;width: 100%;height:100%;">
</div>
<div style="position: absolute; display: block; background: url(img/loading.gif) no-repeat center center;
top: 0px; left: 0px;width: 100%;height:100%;">
</div>
</div>
<!-- Slides Container -->
<div u="slides" style="cursor: move; position: absolute; left: 210px; top: 0px; width: 600px; height: 600px;
overflow: hidden;">
<!-- beginning of PHP Loop -->
<?php
$q = mysql_query("select * from album");
while($albumRes = mysql_fetch_array($q))
{
$i = 1;
$divId = "sliderh" . $i . "_container";
$divClass = "sliderh" . $i;
?>
<div>
<div id="<?php echo $divId ?>" class="<?php echo $divClass ?>" style="position: relative; top: 0px; left: 0px; width: 600px;
height: 600px;">
<!-- Slides Container -->
<div u="slides" style="cursor: move; position: absolute; left: 0px; top: 0px; width: 600px; height: 500px;
overflow: hidden;">
<!-- Begin images loop -->
<?php
$img_query = mysql_query("select * from gallery_images where IMG_AB_ID='$albumRes[0]'");
while($imageRes = mysql_fetch_array($img_query))
{
?>
<div>
<img u="image" src="<?php echo fix_directory($imageRes[2]) ?>" />
<img u="thumb" src="<?php echo fix_directory($imageRes[2]) ?>" />
</div>
<?php } ?>
<!-- End images loop -->
</div>
<!-- thumbnail navigator container (bottom row thumbnails)-->
<div u="thumbnavigator" class="jssort05" style="left: 0px; bottom: 0px;">
<!-- Thumbnail Item Skin Begin -->
<div u="slides" style="cursor: default;">
<div u="prototype" class="p">
<div class="o">
<div u="thumbnailtemplate" class="b"></div>
<div class="i"></div>
<div u="thumbnailtemplate" class="f"></div>
</div>
</div>
</div>
<!-- Thumbnail Item Skin End -->
</div>
<!--#endregion Bullet Navigator Skin End -->
</div>
<div u="thumb">
<img src="<?php echo fix_directory($albumRes[3]) ?>" />
<div class="title_back"></div>
<div class="title">
<?php echo $albumRes[1]?>
</div>
</div>
</div>
<!-- End of Album Loop -->
<?php
$i = $i + 1;
}
?>
</div> <!--#region Thumbnail Navigator Skin Begin -->
<!-- Help: http://www.jssor.com/development/slider-with-thumbnail-navigator-jquery.html -->
<!-- thumbnail navigator container -->
<div u="thumbnavigator" class="jssort16" style="left: 0px; top: 0px;">
<!-- Thumbnail Item Skin Begin -->
<div u="slides" style="cursor: default;">
<div u="prototype" class=p>
<div u="thumbnailtemplate" class="t"></div>
</div>
</div>
<!-- Thumbnail Item Skin End -->
</div>
<!--#endregion Thumbnail Navigator Skin End
<a style="display: none" href="http://www.jssor.com">Bootstrap Slider</a>-->
<!-- Trigger -->
<script>
jssor_slider1_starter('slider1_container');
</script>
</div>
</div>
<!-- Jssor Slider End -->
<?php
} //end else statement for page 2 (gallery page)
?>
脚本代码如下:
<script>
// get number of albums from DB and PHP
var div = document.getElementById("dom-target");
var numAlbums = div.textContent;
// generate array for each function based on
var sliderArray = [];
for(var i = 0; i < numAlbums; i++)
{
// add first container
if(i === 0)
{
sliderArray.push("sliderh1_container");
}
else // add any existing containers for albums after that
{
var num = i + 1;
var n = num.toString();
sliderArray.push("sliderh" + n + "_container");
}
// output to console for testing purposes
console.log(sliderArray);
}
jssor_slider1_starter = function (containerId) {
var nestedSliders = [];
$Jssor$.$Each(sliderArray, function (containerId) {
var nestedSliderOptions = {
$PauseOnHover: 1, //[Optional] Whether to pause when mouse over if a slider is auto playing, 0 no pause, 1 pause for desktop, 2 pause for touch device, 3 pause for desktop and touch device, 4 freeze for desktop, 8 freeze for touch device, 12 freeze for desktop and touch device, default value is 1
$SlideDuration: 500, //[Optional] Specifies default duration (swipe) for slide in milliseconds, default value is 500
$MinDragOffsetToSlide: 20, //[Optional] Minimum drag offset to trigger slide , default value is 20
//$SlideWidth: 200, //[Optional] Width of every slide in pixels, default value is width of 'slides' container
//$SlideHeight: 150, //[Optional] Height of every slide in pixels, default value is height of 'slides' container
$SlideSpacing: 3, //[Optional] Space between each slide in pixels, default value is 0
$Cols: 1, //[Optional] Number of pieces to display (the slideshow would be disabled if the value is set to greater than 1), the default value is 1
$Align: 0, //[Optional] The offset position to park slide (this options applys only when slideshow disabled), default value is 0.
$UISearchMode: 0, //[Optional] The way (0 parellel, 1 recursive, default value is 1) to search UI components (slides container, loading screen, navigator container, arrow navigator container, thumbnail navigator container etc).
$ThumbnailNavigatorOptions: { //[Optional] Options to specify and enable thumbnail navigator or not
$Class: $JssorThumbnailNavigator$, //[Required] Class to create thumbnail navigator instance
$ChanceToShow: 2, //[Required] 0 Never, 1 Mouse Over, 2 Always
$ActionMode: 1, //[Optional] 0 None, 1 act by click, 2 act by mouse hover, 3 both, default value is 1
$SpacingX: 8, //[Optional] Horizontal space between each thumbnail in pixel, default value is 0
$Cols: 10, //[Optional] Number of pieces to display, default value is 1
$Align: 360 //[Optional] The offset position to park thumbnail
}
};
nestedSliders.push(new $JssorSlider$(containerId, nestedSliderOptions));
});
var options = {
$AutoPlay: false, //[Optional] Whether to auto play, to enable slideshow, this option must be set to true, default value is false
$AutoPlaySteps: 1, //[Optional] Steps to go for each navigation request (this options applys only when slideshow disabled), the default value is 1
$AutoPlayInterval: 2000, //[Optional] Interval (in milliseconds) to go for next slide since the previous stopped if the slider is auto playing, default value is 3000
$PauseOnHover: 1, //[Optional] Whether to pause when mouse over if a slider is auto playing, 0 no pause, 1 pause for desktop, 2 pause for touch device, 3 pause for desktop and touch device, 4 freeze for desktop, 8 freeze for touch device, 12 freeze for desktop and touch device, default value is 1
$ArrowKeyNavigation: true, //[Optional] Allows keyboard (arrow key) navigation or not, default value is false
$SlideDuration: 300, //[Optional] Specifies default duration (swipe) for slide in milliseconds, default value is 500
$MinDragOffsetToSlide: 80, //[Optional] Minimum drag offset to trigger slide , default value is 20
//$SlideWidth: 600, //[Optional] Width of every slide in pixels, default value is width of 'slides' container
//$SlideHeight: 150, //[Optional] Height of every slide in pixels, default value is height of 'slides' container
$SlideSpacing: 3, //[Optional] Space between each slide in pixels, default value is 0
$Cols: 1, //[Optional] Number of pieces to display (the slideshow would be disabled if the value is set to greater than 1), the default value is 1
$Align: 0, //[Optional] The offset position to park slide (this options applys only when slideshow disabled), default value is 0.
$UISearchMode: 0, //[Optional] The way (0 parellel, 1 recursive, default value is 1) to search UI components (slides container, loading screen, navigator container, arrow navigator container, thumbnail navigator container etc).
$PlayOrientation: 2, //[Optional] Orientation to play slide (for auto play, navigation), 1 horizental, 2 vertical, 5 horizental reverse, 6 vertical reverse, default value is 1
$DragOrientation: 0, //[Optional] Orientation to drag slide, 0 no drag, 1 horizental, 2 vertical, 3 either, default value is 1 (Note that the $DragOrientation should be the same as $PlayOrientation when $Cols is greater than 1, or parking position is not 0),
$ThumbnailNavigatorOptions: {
$Class: $JssorThumbnailNavigator$, //[Required] Class to create thumbnail navigator instance
$ChanceToShow: 2, //[Required] 0 Never, 1 Mouse Over, 2 Always
$ActionMode: 1, //[Optional] 0 None, 1 act by click, 2 act by mouse hover, 3 both, default value is 1
$AutoCenter: 3, //[Optional] Auto center thumbnail items in the thumbnail navigator container, 0 None, 1 Horizontal, 2 Vertical, 3 Both, default value is 3
$Rows: 1, //[Optional] Specify lanes to arrange thumbnails, default value is 1
$SpacingX: 10, //[Optional] Horizontal space between each thumbnail in pixel, default value is 0
$SpacingY: 10, //[Optional] Vertical space between each thumbnail in pixel, default value is 0
$Cols: 3, //[Optional] Number of pieces to display, default value is 1
$Align: 0, //[Optional] The offset position to park thumbnail
$Orientation: 2, //[Optional] Orientation to arrange thumbnails, 1 horizental, 2 vertical, default value is 1
$NoDrag: false //[Optional] Disable drag or not, default value is false
}
};
var jssor_slider1 = new $JssorSlider$(containerId, options);
function OnMainSliderPark(currentIndex, fromIndex) {
$Jssor$.$Each(nestedSliders, function (nestedSlider) {
nestedSlider.$Pause();
});
setTimeout(function () {
nestedSliders[currentIndex].$Play();
}, 2000);
}
jssor_slider1.$On($JssorSlider$.$EVT_PARK, OnMainSliderPark);
OnMainSliderPark(0, 0);
//responsive code begin
//you can remove responsive code if you don't want the slider scales while window resizes
function ScaleSlider() {
var parentWidth = jssor_slider1.$Elmt.parentNode.clientWidth;
if (parentWidth)
jssor_slider1.$ScaleWidth(Math.min(parentWidth, 800));
else
$Jssor$.$Delay(ScaleSlider, 30);
}
ScaleSlider();
$Jssor$.$AddEvent(window, "load", ScaleSlider);
$Jssor$.$AddEvent(window, "resize", $Jssor$.$WindowResizeFilter(window, ScaleSlider));
$Jssor$.$AddEvent(window, "orientationchange", ScaleSlider);
//responsive code end
};
</script>
嗯...我想这是业余时间,但我发现也许我不应该在 while 循环中声明计数器变量。案件结案。
我正在尝试创建一个动态 jssor 嵌套滑块,它将显示 mySQL 数据库中的相册和相关图像。现在,它只适用于一张专辑,但当数据库中存在两个或更多专辑时,它无法正确显示。我对 JavaScript 和 JQuery 比较陌生。下面是我的代码。
<div id="slider1_container" style="position: relative; top: 0px; left: 0px; width: 810px; height: 600px; background: #24262e; overflow: hidden; ">
<!-- Loading Screen -->
<div u="loading" style="position: absolute; top: 0px; left: 0px;">
<div style="filter: alpha(opacity=70); opacity:0.7; position: absolute; display: block;
background-color: #000; top: 0px; left: 0px;width: 100%;height:100%;">
</div>
<div style="position: absolute; display: block; background: url(img/loading.gif) no-repeat center center;
top: 0px; left: 0px;width: 100%;height:100%;">
</div>
</div>
<!-- Slides Container -->
<div u="slides" style="cursor: move; position: absolute; left: 210px; top: 0px; width: 600px; height: 600px;
overflow: hidden;">
<!-- beginning of PHP Loop -->
<?php
$q = mysql_query("select * from album");
while($albumRes = mysql_fetch_array($q))
{
$i = 1;
$divId = "sliderh" . $i . "_container";
$divClass = "sliderh" . $i;
?>
<div>
<div id="<?php echo $divId ?>" class="<?php echo $divClass ?>" style="position: relative; top: 0px; left: 0px; width: 600px;
height: 600px;">
<!-- Slides Container -->
<div u="slides" style="cursor: move; position: absolute; left: 0px; top: 0px; width: 600px; height: 500px;
overflow: hidden;">
<!-- Begin images loop -->
<?php
$img_query = mysql_query("select * from gallery_images where IMG_AB_ID='$albumRes[0]'");
while($imageRes = mysql_fetch_array($img_query))
{
?>
<div>
<img u="image" src="<?php echo fix_directory($imageRes[2]) ?>" />
<img u="thumb" src="<?php echo fix_directory($imageRes[2]) ?>" />
</div>
<?php } ?>
<!-- End images loop -->
</div>
<!-- thumbnail navigator container (bottom row thumbnails)-->
<div u="thumbnavigator" class="jssort05" style="left: 0px; bottom: 0px;">
<!-- Thumbnail Item Skin Begin -->
<div u="slides" style="cursor: default;">
<div u="prototype" class="p">
<div class="o">
<div u="thumbnailtemplate" class="b"></div>
<div class="i"></div>
<div u="thumbnailtemplate" class="f"></div>
</div>
</div>
</div>
<!-- Thumbnail Item Skin End -->
</div>
<!--#endregion Bullet Navigator Skin End -->
</div>
<div u="thumb">
<img src="<?php echo fix_directory($albumRes[3]) ?>" />
<div class="title_back"></div>
<div class="title">
<?php echo $albumRes[1]?>
</div>
</div>
</div>
<!-- End of Album Loop -->
<?php
$i = $i + 1;
}
?>
</div> <!--#region Thumbnail Navigator Skin Begin -->
<!-- Help: http://www.jssor.com/development/slider-with-thumbnail-navigator-jquery.html -->
<!-- thumbnail navigator container -->
<div u="thumbnavigator" class="jssort16" style="left: 0px; top: 0px;">
<!-- Thumbnail Item Skin Begin -->
<div u="slides" style="cursor: default;">
<div u="prototype" class=p>
<div u="thumbnailtemplate" class="t"></div>
</div>
</div>
<!-- Thumbnail Item Skin End -->
</div>
<!--#endregion Thumbnail Navigator Skin End
<a style="display: none" href="http://www.jssor.com">Bootstrap Slider</a>-->
<!-- Trigger -->
<script>
jssor_slider1_starter('slider1_container');
</script>
</div>
</div>
<!-- Jssor Slider End -->
<?php
} //end else statement for page 2 (gallery page)
?>
脚本代码如下:
<script>
// get number of albums from DB and PHP
var div = document.getElementById("dom-target");
var numAlbums = div.textContent;
// generate array for each function based on
var sliderArray = [];
for(var i = 0; i < numAlbums; i++)
{
// add first container
if(i === 0)
{
sliderArray.push("sliderh1_container");
}
else // add any existing containers for albums after that
{
var num = i + 1;
var n = num.toString();
sliderArray.push("sliderh" + n + "_container");
}
// output to console for testing purposes
console.log(sliderArray);
}
jssor_slider1_starter = function (containerId) {
var nestedSliders = [];
$Jssor$.$Each(sliderArray, function (containerId) {
var nestedSliderOptions = {
$PauseOnHover: 1, //[Optional] Whether to pause when mouse over if a slider is auto playing, 0 no pause, 1 pause for desktop, 2 pause for touch device, 3 pause for desktop and touch device, 4 freeze for desktop, 8 freeze for touch device, 12 freeze for desktop and touch device, default value is 1
$SlideDuration: 500, //[Optional] Specifies default duration (swipe) for slide in milliseconds, default value is 500
$MinDragOffsetToSlide: 20, //[Optional] Minimum drag offset to trigger slide , default value is 20
//$SlideWidth: 200, //[Optional] Width of every slide in pixels, default value is width of 'slides' container
//$SlideHeight: 150, //[Optional] Height of every slide in pixels, default value is height of 'slides' container
$SlideSpacing: 3, //[Optional] Space between each slide in pixels, default value is 0
$Cols: 1, //[Optional] Number of pieces to display (the slideshow would be disabled if the value is set to greater than 1), the default value is 1
$Align: 0, //[Optional] The offset position to park slide (this options applys only when slideshow disabled), default value is 0.
$UISearchMode: 0, //[Optional] The way (0 parellel, 1 recursive, default value is 1) to search UI components (slides container, loading screen, navigator container, arrow navigator container, thumbnail navigator container etc).
$ThumbnailNavigatorOptions: { //[Optional] Options to specify and enable thumbnail navigator or not
$Class: $JssorThumbnailNavigator$, //[Required] Class to create thumbnail navigator instance
$ChanceToShow: 2, //[Required] 0 Never, 1 Mouse Over, 2 Always
$ActionMode: 1, //[Optional] 0 None, 1 act by click, 2 act by mouse hover, 3 both, default value is 1
$SpacingX: 8, //[Optional] Horizontal space between each thumbnail in pixel, default value is 0
$Cols: 10, //[Optional] Number of pieces to display, default value is 1
$Align: 360 //[Optional] The offset position to park thumbnail
}
};
nestedSliders.push(new $JssorSlider$(containerId, nestedSliderOptions));
});
var options = {
$AutoPlay: false, //[Optional] Whether to auto play, to enable slideshow, this option must be set to true, default value is false
$AutoPlaySteps: 1, //[Optional] Steps to go for each navigation request (this options applys only when slideshow disabled), the default value is 1
$AutoPlayInterval: 2000, //[Optional] Interval (in milliseconds) to go for next slide since the previous stopped if the slider is auto playing, default value is 3000
$PauseOnHover: 1, //[Optional] Whether to pause when mouse over if a slider is auto playing, 0 no pause, 1 pause for desktop, 2 pause for touch device, 3 pause for desktop and touch device, 4 freeze for desktop, 8 freeze for touch device, 12 freeze for desktop and touch device, default value is 1
$ArrowKeyNavigation: true, //[Optional] Allows keyboard (arrow key) navigation or not, default value is false
$SlideDuration: 300, //[Optional] Specifies default duration (swipe) for slide in milliseconds, default value is 500
$MinDragOffsetToSlide: 80, //[Optional] Minimum drag offset to trigger slide , default value is 20
//$SlideWidth: 600, //[Optional] Width of every slide in pixels, default value is width of 'slides' container
//$SlideHeight: 150, //[Optional] Height of every slide in pixels, default value is height of 'slides' container
$SlideSpacing: 3, //[Optional] Space between each slide in pixels, default value is 0
$Cols: 1, //[Optional] Number of pieces to display (the slideshow would be disabled if the value is set to greater than 1), the default value is 1
$Align: 0, //[Optional] The offset position to park slide (this options applys only when slideshow disabled), default value is 0.
$UISearchMode: 0, //[Optional] The way (0 parellel, 1 recursive, default value is 1) to search UI components (slides container, loading screen, navigator container, arrow navigator container, thumbnail navigator container etc).
$PlayOrientation: 2, //[Optional] Orientation to play slide (for auto play, navigation), 1 horizental, 2 vertical, 5 horizental reverse, 6 vertical reverse, default value is 1
$DragOrientation: 0, //[Optional] Orientation to drag slide, 0 no drag, 1 horizental, 2 vertical, 3 either, default value is 1 (Note that the $DragOrientation should be the same as $PlayOrientation when $Cols is greater than 1, or parking position is not 0),
$ThumbnailNavigatorOptions: {
$Class: $JssorThumbnailNavigator$, //[Required] Class to create thumbnail navigator instance
$ChanceToShow: 2, //[Required] 0 Never, 1 Mouse Over, 2 Always
$ActionMode: 1, //[Optional] 0 None, 1 act by click, 2 act by mouse hover, 3 both, default value is 1
$AutoCenter: 3, //[Optional] Auto center thumbnail items in the thumbnail navigator container, 0 None, 1 Horizontal, 2 Vertical, 3 Both, default value is 3
$Rows: 1, //[Optional] Specify lanes to arrange thumbnails, default value is 1
$SpacingX: 10, //[Optional] Horizontal space between each thumbnail in pixel, default value is 0
$SpacingY: 10, //[Optional] Vertical space between each thumbnail in pixel, default value is 0
$Cols: 3, //[Optional] Number of pieces to display, default value is 1
$Align: 0, //[Optional] The offset position to park thumbnail
$Orientation: 2, //[Optional] Orientation to arrange thumbnails, 1 horizental, 2 vertical, default value is 1
$NoDrag: false //[Optional] Disable drag or not, default value is false
}
};
var jssor_slider1 = new $JssorSlider$(containerId, options);
function OnMainSliderPark(currentIndex, fromIndex) {
$Jssor$.$Each(nestedSliders, function (nestedSlider) {
nestedSlider.$Pause();
});
setTimeout(function () {
nestedSliders[currentIndex].$Play();
}, 2000);
}
jssor_slider1.$On($JssorSlider$.$EVT_PARK, OnMainSliderPark);
OnMainSliderPark(0, 0);
//responsive code begin
//you can remove responsive code if you don't want the slider scales while window resizes
function ScaleSlider() {
var parentWidth = jssor_slider1.$Elmt.parentNode.clientWidth;
if (parentWidth)
jssor_slider1.$ScaleWidth(Math.min(parentWidth, 800));
else
$Jssor$.$Delay(ScaleSlider, 30);
}
ScaleSlider();
$Jssor$.$AddEvent(window, "load", ScaleSlider);
$Jssor$.$AddEvent(window, "resize", $Jssor$.$WindowResizeFilter(window, ScaleSlider));
$Jssor$.$AddEvent(window, "orientationchange", ScaleSlider);
//responsive code end
};
</script>
嗯...我想这是业余时间,但我发现也许我不应该在 while 循环中声明计数器变量。案件结案。