Javascript JS滑块在淡入淡出时四处跳跃

Javascript JS滑块在淡入淡出时四处跳跃,javascript,jquery,html,css,Javascript,Jquery,Html,Css,我有一个问题,我的js滑块的行为是奇怪的。我在标题顶部调用Jquery。JS脚本位于底部 页面加载时会显示所有三张幻灯片,并快速显示第一张幻灯片,隐藏其他两张幻灯片。当他们淡入淡出到下一张幻灯片等时,内容会跳下来 您可以在此处看到行为: 这是JS // settings var $slider = $('.slider'); // class or id of carousel slider var $slide = 'li'; // could also use 'img' if you're

我有一个问题,我的js滑块的行为是奇怪的。我在标题顶部调用Jquery。JS脚本位于底部

页面加载时会显示所有三张幻灯片,并快速显示第一张幻灯片,隐藏其他两张幻灯片。当他们淡入淡出到下一张幻灯片等时,内容会跳下来

您可以在此处看到行为:

这是JS

// settings
var $slider = $('.slider'); // class or id of carousel slider
var $slide = 'li'; // could also use 'img' if you're not using a ul
var $transition_time = 1000; // 1 second
var $time_between_slides = 3000; // 4 seconds

function slides(){
  return $slider.find($slide);
}

slides().fadeOut();

// set active classes
slides().first().addClass('active');
slides().first().fadeIn($transition_time);

// auto scroll 
$interval = setInterval(
    function(){
      var $i = $slider.find($slide + '.active').index();

      slides().eq($i).removeClass('active');
      slides().eq($i).fadeOut($transition_time);

      if (slides().length == $i + 1) $i = -1; // loop to start

      slides().eq($i + 1).fadeIn($transition_time);
      slides().eq($i + 1).addClass('active');
    }
    , $transition_time +  $time_between_slides 
);

只需将
位置:绝对
放在
ullì
上即可

ul li {
  position:absolute
}
JSFIDLE:。
你有它的
位置:static
,它将它保持在文档流中,并将其他元素推开。

只需将
位置:absolute
放在
ul lì
上即可

ul li {
  position:absolute
}
JSFIDLE:。
你有它的
位置:static
,它将它保持在文档流中,并将其他元素推开。

只需将
位置:absolute
放在
ul lì
上即可

ul li {
  position:absolute
}
JSFIDLE:。
你有它的
位置:static
,它将它保持在文档流中,并将其他元素推开。

只需将
位置:absolute
放在
ul lì
上即可

ul li {
  position:absolute
}
JSFIDLE:。
您有它的
位置:static
,它将它保留在文档流中,并将其他元素推开。

在淡出功能完成后调用淡出功能


在淡出功能完成后调用淡出功能


在淡出功能完成后调用淡出功能


在淡出功能完成后调用淡出功能


这是因为您的移入和移出同时发生,所以移入淡入会在移出元素下创建一个元素。试着这样做:

// settings
var $slider = $('.slider'); // class or id of carousel slider
var $slide = 'li'; // could also use 'img' if you're not using a ul
var $transition_time = 1000; // 1 second
var $time_between_slides = 3000; // 4 seconds

function slides() {
  return $slider.find($slide);
}

slides().fadeOut();

// set active classes
slides().first().addClass('active');
slides().first().fadeIn($transition_time);

// auto scroll 
$interval = setInterval(

function () {
 var $i = $slider.find($slide + '.active').index();

 slides().eq($i).removeClass('active');
 slides().eq($i).fadeOut($transition_time/2, function(){
     if (slides().length == $i + 1) $i = -1; // loop to start

     slides().eq($i + 1).fadeIn($transition_time/2);
     slides().eq($i + 1).addClass('active');
 });


}, $transition_time + $time_between_slides);

这是因为您的移入和移出同时发生-因此“移入淡入”会在“移出”元素下创建一个元素。试着这样做:

// settings
var $slider = $('.slider'); // class or id of carousel slider
var $slide = 'li'; // could also use 'img' if you're not using a ul
var $transition_time = 1000; // 1 second
var $time_between_slides = 3000; // 4 seconds

function slides() {
  return $slider.find($slide);
}

slides().fadeOut();

// set active classes
slides().first().addClass('active');
slides().first().fadeIn($transition_time);

// auto scroll 
$interval = setInterval(

function () {
 var $i = $slider.find($slide + '.active').index();

 slides().eq($i).removeClass('active');
 slides().eq($i).fadeOut($transition_time/2, function(){
     if (slides().length == $i + 1) $i = -1; // loop to start

     slides().eq($i + 1).fadeIn($transition_time/2);
     slides().eq($i + 1).addClass('active');
 });


}, $transition_time + $time_between_slides);

这是因为您的移入和移出同时发生-因此“移入淡入”会在“移出”元素下创建一个元素。试着这样做:

// settings
var $slider = $('.slider'); // class or id of carousel slider
var $slide = 'li'; // could also use 'img' if you're not using a ul
var $transition_time = 1000; // 1 second
var $time_between_slides = 3000; // 4 seconds

function slides() {
  return $slider.find($slide);
}

slides().fadeOut();

// set active classes
slides().first().addClass('active');
slides().first().fadeIn($transition_time);

// auto scroll 
$interval = setInterval(

function () {
 var $i = $slider.find($slide + '.active').index();

 slides().eq($i).removeClass('active');
 slides().eq($i).fadeOut($transition_time/2, function(){
     if (slides().length == $i + 1) $i = -1; // loop to start

     slides().eq($i + 1).fadeIn($transition_time/2);
     slides().eq($i + 1).addClass('active');
 });


}, $transition_time + $time_between_slides);

这是因为您的移入和移出同时发生-因此“移入淡入”会在“移出”元素下创建一个元素。试着这样做:

// settings
var $slider = $('.slider'); // class or id of carousel slider
var $slide = 'li'; // could also use 'img' if you're not using a ul
var $transition_time = 1000; // 1 second
var $time_between_slides = 3000; // 4 seconds

function slides() {
  return $slider.find($slide);
}

slides().fadeOut();

// set active classes
slides().first().addClass('active');
slides().first().fadeIn($transition_time);

// auto scroll 
$interval = setInterval(

function () {
 var $i = $slider.find($slide + '.active').index();

 slides().eq($i).removeClass('active');
 slides().eq($i).fadeOut($transition_time/2, function(){
     if (slides().length == $i + 1) $i = -1; // loop to start

     slides().eq($i + 1).fadeIn($transition_time/2);
     slides().eq($i + 1).addClass('active');
 });


}, $transition_time + $time_between_slides);

这里有一个更新的
jsfiddle

fadeout
需要时间,因此您必须在回调函数中延迟
fadein

slides().eq($i).fadeOut($transition_time, function() {
    if (slides().length == $i + 1) $i = -1; // loop to start
    slides().eq($i + 1).fadeIn($transition_time);
    slides().eq($i + 1).addClass('active');  
});

您还可以使用
slides().hide()在启动时隐藏所有幻灯片
这里有一个更新的
jsfiddle

fadeout
需要时间,因此您必须在回调函数中延迟
fadein

slides().eq($i).fadeOut($transition_time, function() {
    if (slides().length == $i + 1) $i = -1; // loop to start
    slides().eq($i + 1).fadeIn($transition_time);
    slides().eq($i + 1).addClass('active');  
});

您还可以使用
slides().hide()在启动时隐藏所有幻灯片
这里有一个更新的
jsfiddle

fadeout
需要时间,因此您必须在回调函数中延迟
fadein

slides().eq($i).fadeOut($transition_time, function() {
    if (slides().length == $i + 1) $i = -1; // loop to start
    slides().eq($i + 1).fadeIn($transition_time);
    slides().eq($i + 1).addClass('active');  
});

您还可以使用
slides().hide()在启动时隐藏所有幻灯片
这里有一个更新的
jsfiddle

fadeout
需要时间,因此您必须在回调函数中延迟
fadein

slides().eq($i).fadeOut($transition_time, function() {
    if (slides().length == $i + 1) $i = -1; // loop to start
    slides().eq($i + 1).fadeIn($transition_time);
    slides().eq($i + 1).addClass('active');  
});
您还可以使用
slides().hide()在启动时隐藏所有幻灯片

在这里工作

你的转变是同时发生的,所以它不是平稳的转变。您还应该在开始时隐藏元素,而不是淡出以防止初始行为。

在此处使用JSFIDLE

你的转变是同时发生的,所以它不是平稳的转变。您还应该在开始时隐藏元素,而不是淡出以防止初始行为。

在此处使用JSFIDLE

你的转变是同时发生的,所以它不是平稳的转变。您还应该在开始时隐藏元素,而不是淡出以防止初始行为。

在此处使用JSFIDLE


你的转变是同时发生的,所以它不是平稳的转变。您还应该最初隐藏元素,而不是淡出,以防止初始行为。

这将使过渡时间加倍。因此,要么减少转换时间变量,要么将每次使用除以2,这将使转换时间加倍。因此,要么减少转换时间变量,要么将每次使用除以2,这将使转换时间加倍。因此,要么减少转换时间变量,要么将每次使用除以2,这将使转换时间加倍。因此,要么减少转换时间变量,要么将每次使用除以2