花了一上午来调整页面在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';
};

基于css3的轮播效果的更多相关文章

  1. CSS3图片轮播效果

    原文:CSS3图片轮播效果 在网页中用到图片轮播效果,单纯的隐藏.显示,那再简单不过了,要有动画效果,如果是自己写的话(不用jquery等),可能要费点时间.css3的出现,让动画变得不再是问题,而且 ...

  2. css3爆炸轮播效果

    <!DOCTYPE html><html lang="zh-cn"><head> <meta charset="UTF-8&qu ...

  3. CSS3实现轮播图效果

    CSS3实现轮播图主要是由css:background-position和css3:animation实现.且实现此轮播需要一张四个图横着相连的图片. 注(Internet Explorer 10.F ...

  4. css3关键帧动画实现轮播效果

    实现效果:打开手机京东,可以看到首页的头部,以这个头部为基础,仿写一个类似的样式. 思路:仔细观察可以发现,手机京东的头部是以一个搜索栏和轮播特效组成的,而这个搜索栏是以轮播特效做为背景的,现在运用c ...

  5. css3动画使用技巧之—JQ配合css3实现轮播之animation-delay应用

    <!DOCTYPE html> <html> <head> <title>css3动画使用技巧之—JQ配合css3实现轮播之animation-dela ...

  6. 基于css制作轮播图的部分效果

    在轮播图中,我们可以通过鼠标在特定位置上的滑动来实现元素背景的改变.通常在制作轮播图时,我们首先想到的是js中的交互.可是,如果我们无法使用js,只能单纯的靠css又该如何实现这一效果呢?下面,本人将 ...

  7. 针对淡入淡出的定时轮播效果js

    如果不使用jquery的fadeIn和fadeOut的接口和不适用animate情况下,如果要做用js实现淡入淡出轮播效果,我所想到的办法就是使用css3新特性transition(注意好兼容性). ...

  8. 纯CSS3实现轮播图

    前言 纯css3实现的轮播图效果,和JavaScript控制的相比,简单高效了很多,但是功能也更加单一,只有轮播不能手动切换. 用什么实现的呢?页面布局 + animation动画 HTML部分 &l ...

  9. iOS 封装跑马灯和轮播效果

    代码地址如下:http://www.demodashi.com/demo/14075.html 功能概述和预览 功能描述:WSL_RollView 是基于UICollectionView实现的支持水平 ...

随机推荐

  1. <js>实现回车键登陆方法,并处理谷歌与火狐不兼容的问题

    1.在body中添加onkeydown事件 <body onkeydown="keyLogin(event);">2.使用js相应登陆添加方法//添加回车登陆事件 fu ...

  2. mysql5.7下的timestampn Error : Invalid default value for 'timestamp'

    表格创建是爆了个错 Error : Invalid default value for 'timestamp' 参考:http://www.jb51.net/article/71107.htm 这版本 ...

  3. Centos7下配置Redis开机自启动

    最近在做作业的时候需要用到Redis缓存,由于每次重启服务器都需要重新启动Redis,也是忒烦人,于是就有了这一篇博客,好,废话不多说. 只有两个步骤: 设置redis.conf中daemonize为 ...

  4. 十天精通CSS3学习笔记 part3

    第8章 CSS3中的变形与动画(上) 变形--旋转 rotate() 旋转rotate()函数通过指定的角度参数使元素相对原点进行旋转.它主要在二维空间内进行操作,设置一个角度值,用来指定旋转的幅度. ...

  5. 获取sql server数据库表结构

    if exists (select 1 from sysobjects where name = 'sysproperties'and xtype = 'V')begin    DROP VIEW s ...

  6. jmeter for循环嵌套if学习1

    测试计划组成:      vcondition的值都是tom. 执行结果:

  7. 实现远程FTP特定时间轨道号MODIS数据的搜索

    private ArrayList alst = new System.Collections.ArrayList();//建立ArrayList对象 int strLength = 0; strin ...

  8. 使用COALESCE时注意left join为null的情况

    1.使用COALESCE时,用到group by with cube,如果之前两个表left join时,有数据为null,就会使得查出的数据主键不唯一 例如: select COALESCE (c. ...

  9. guava学习--FutureCallback

    转载:https://my.oschina.net/realfighter/blog/349929 Guava提供了 FutureCallback接口,FutureCallback接口提供了onSuc ...

  10. ASP.net Core部署说明(Ubuntu) [转]

    最近在学习asp.net core,当然学习的目的是想了解一下,Asp.net core是否真的能够是先跨平台部署. 根据目前官网资料说明,asp.net core只有在Redhat 企业版上,才能够 ...