基于css3的轮播效果

时间:2021-03-01 22:43:09

  花了一上午来调整页面在ie10上的显示问题,sass编译生成的css文件在ie内核下一直不能正确加载,果然兼容性的问题还需要好好研究。转入正题,用css3实现轮播效果主要是基于css3的framework动画效果实现轮播效果以及之前提到的input:checked伪类来实现轮播的控制。在轮播的控制上不可避免的使用了js,一直想写出优雅的js代码,在看了自己写的代码之后发现自己还有很大的提升空间,也许该找个机会去阅读优秀框架的源代码了。

  当然也借鉴了网上很多资料,有问题的是在ie下完全没有效果,对轮播导航的实现也比较死板,能够改进的地方很多。假设我们的轮播图有三张。将ul.carousel-wrap的宽度设置为300%,也就是3倍的div.carousel的宽度 overflow:hidden 而ul的子li 元素设置宽度为正好div.carousel的宽度 并且设置左浮动保证li的正常显示。这时候我们只要为ul设置keyframes来设置margin-left 给一个负值就能实现轮播的动画效果了。至于导航栏的控制,用input:checked来控制动画的切换,用:active伪类来模拟动画的重新启动。设定一个定时器setinterval来实现轮播导航随着轮播移动。并且维持一个labelSelect的哨兵值来控制记录当前轮播图的位置信息。当label被点击的时候,改变labelSelect的值并且重启定时器来消除时间差。

<div class="carousel">                                       
  <input type="radio" name="slide" checked id="l01">    
  <input type="radio" name="slide" id="l02">
  <input type="radio" name="slide" id="l03">
  <ul class="carousel-wrap">
    <li class="carousel-item"></li>
    <li class="carousel-item"></li>
    <li class="carousel-item"></li>
  </ul>
  <div class="label-wrap" id="label-group">
    <label for="l01" id="label1"></label>
    <label for="l02" id="label2"></label>
    <label for="l03" id="label3"></label>
  </div>
</div>

js代码却是需要改进的地方还有很多,感觉自己的能力离es6还有很大的距离,希望一个月之后能写出比写在高效,优雅的多的js代码。部分js代码如下(大致描述了基本思路):

//轮播导航条随轮播变化变化
var label1 = document.getElementById('label1');
label1.style.backgroundColor = '#c70025';
var label2 = document.getElementById('label2');
var label3 = document.getElementById('label3');
//当前轮播位置
var labelSelect = 1;
if(!!label1.addEventListener){
  label1.addEventListener("click",function(){
    var input1 = document.getElementById('l01');
    if(input1.checked === true){
      input1.checked = false;
     }
    labelSelect = 1;
    //重启定时器消除时间差
    clearInterval(timer);
    timer = setInterval("labelMove()",3000);
    var parent = this.parentNode;
    var sibling = parent.getElementsByTagName('label');
    for(var i = 0 ; i < sibling.length ; i++){
      sibling[i].style.backgroundColor = '#ffffff';
    }
    this.style.backgroundColor = '#c70025';
  });
}else if(!!label1.attachEvent){
  ...
}

var timer = null;
timer = setInterval("labelMove()",3000);

var labelMove = function(){
  var labelGroup = document.getElementById('label-group');
  var labels = labelGroup.getElementsByTagName('label');
  labelSelect = Math.ceil((labelSelect + 1)%3.1);
  for(var i = 0 ; i < labels.length ; i++){
    labels[i].style.backgroundColor = '#ffffff';
  }
  labels[labelSelect - 1].style.backgroundColor = '#c70025';
};