基于css3的轮播效果
花了一上午来调整页面在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的轮播效果的更多相关文章
- CSS3图片轮播效果
原文:CSS3图片轮播效果 在网页中用到图片轮播效果,单纯的隐藏.显示,那再简单不过了,要有动画效果,如果是自己写的话(不用jquery等),可能要费点时间.css3的出现,让动画变得不再是问题,而且 ...
- css3爆炸轮播效果
<!DOCTYPE html><html lang="zh-cn"><head> <meta charset="UTF-8&qu ...
- CSS3实现轮播图效果
CSS3实现轮播图主要是由css:background-position和css3:animation实现.且实现此轮播需要一张四个图横着相连的图片. 注(Internet Explorer 10.F ...
- css3关键帧动画实现轮播效果
实现效果:打开手机京东,可以看到首页的头部,以这个头部为基础,仿写一个类似的样式. 思路:仔细观察可以发现,手机京东的头部是以一个搜索栏和轮播特效组成的,而这个搜索栏是以轮播特效做为背景的,现在运用c ...
- css3动画使用技巧之—JQ配合css3实现轮播之animation-delay应用
<!DOCTYPE html> <html> <head> <title>css3动画使用技巧之—JQ配合css3实现轮播之animation-dela ...
- 基于css制作轮播图的部分效果
在轮播图中,我们可以通过鼠标在特定位置上的滑动来实现元素背景的改变.通常在制作轮播图时,我们首先想到的是js中的交互.可是,如果我们无法使用js,只能单纯的靠css又该如何实现这一效果呢?下面,本人将 ...
- 针对淡入淡出的定时轮播效果js
如果不使用jquery的fadeIn和fadeOut的接口和不适用animate情况下,如果要做用js实现淡入淡出轮播效果,我所想到的办法就是使用css3新特性transition(注意好兼容性). ...
- 纯CSS3实现轮播图
前言 纯css3实现的轮播图效果,和JavaScript控制的相比,简单高效了很多,但是功能也更加单一,只有轮播不能手动切换. 用什么实现的呢?页面布局 + animation动画 HTML部分 &l ...
- iOS 封装跑马灯和轮播效果
代码地址如下:http://www.demodashi.com/demo/14075.html 功能概述和预览 功能描述:WSL_RollView 是基于UICollectionView实现的支持水平 ...
随机推荐
- windows下安装beautifulsoup4
方法一: pip install beautifulsoup4 方法二: 在官网下载安装包后,放在python目录下--运行cmd--进入bs4安装包路径--输入setup.py install 测试 ...
- oracle笔记
一.sql*plus常用命令 (1)connect 用法:conn 用户名/密码@网络服务名[as sysdba/sysoper] 当特权用户连接时,必须带上as sysdba或是as sysoper ...
- Phalapi 中Union和Union All的用法
有时候在进行数据库查询的时候会用到union查询,但是查询的时候会发现两个limit只有一个是有效的,如下查询 select * from table where status = 0 limit 1 ...
- 基础算法之冒泡排序Bubble Sort
原理 将相邻的数据两两进行比较,按照从小到大或者从大到小的顺序进行位置交换,这样一趟过去后,最大或最小的数字被交换到了最后一位,然后从头开始再次进行两两比较交换,直到倒数第二位时结束.按照此规则,若干 ...
- webservice 实现json模式
直接上代码 public string GetUserInfoByOpenid(string openid) { var weixinuser = new WeiXinUser(); weixinus ...
- Win7/Win8/Win8.1/Win10下的DragEnter DragDrop事件不触发
Win7/Win8/Win8.1/Win10下的DragDrop事件不触发 2011-02-02 来自:博客园 字体大小:[大 中 小] 摘要:你的应用程序需要从windows资源管理器拖动文件到 ...
- Javascript学习笔记2.2 Javascript与DOM选项卡(滑动门)案例详解
学习了DOM的知识,今天开始做些练习,想到了一个网页滑动门的特效,见下图: 1.通过建立索引实现 <!doctype html> <html> <head> < ...
- EasyUI相关
失去焦点事件 validType:'length[4,15]',events:{blur: function(){}} 添加自定义属性 $.extend($.fn.validatebox.defaul ...
- PHP 文件包含总结 include require 命名空间 autoload spl_autoload_register 读取文件路径
总结: 1. include或require包含其他文件 使用./或者 ../,这里的当前路径和上一层路径,取决于运行脚本的路径,会存在如下问题. 在写PHP程序时,经常要用到include或requ ...
- redhat openshift 跳转
网址: https://openshift.redhat.com/ OpenShift免费套餐的限制是:最多15PV/s,有3个512MB内存的应用,月流量在50K以下. 可以绑米,可惜的是,需要代理 ...