前端工程师实现轮播图有好多种方式,有的喜欢使用自己编写的脚本,有的喜欢使用JQurey,有的喜欢使用swiper插件,不过很少有人会单纯的使用CSS来实现轮播图。
使用CSS实现轮播图操作主要使用了伪类:checked,并将lable指向对应的input的id,来实现这个轮播的功能。
首先我们要有一个容器用来防止轮播图,这里使用的p来代替,HTML页面的代码如下:
轮播图CSS样式,这里用的ul-p,需要的话可以再写代码时用图片表示,这里仅仅是简要的表示一下:
label标签用来放置按钮,通过label来控制轮播图的切换,关于其具体的样式在实际开发中进行调整即可。
最后就是实现css轮播图的核心,主要通过使用控制控制margin值来实现轮播的而效果。
实现图片的透明度渐变效果,效果如下:
先说下我的实现,并没有用什么黑科技,而是通过两层图层堆叠的方式来做的。下面一层就是单纯的 svg 图片,上面覆盖了一层遮罩,并设置遮罩的背景色为蓝色到透明色的从左到右渐变。这样,看上去就是一个图片从右到左渐渐变得透明的效果。
这是我比较粗暴的方法,后来在网上看到一种更加优雅的方式:
大体上差不多,重点是 CSS 的 background-image 属性可以设置多张图片,用逗号隔开 。因为我不知道这个属性有这个能力才会额外加了个渐变透明图层来实现效果。
通过css3和DOM操作,可以实现多种图片浏览的效果 但是大致思路都是一致的:1)通过DOM操作循环创建出来一组元素
document.createElement('标签名');
父级.appendChild('obj')
2)给每一个创建出来的元素添加transform变换效果
obj.style.transform=' rotateX(30deg)'
obj.style.transition='1s all ease'
3)当变换结束的时候,瞬间拉回变换并换底图
obj.addEventListener('transitionend',function(){},false}
obj.style.transform=' rotateX(0deg)'
obj.style.transition='none'
当前要显示的一面:url("img/'+iNow%3+'.jpg");
即将要显示的一面:url("img/'+(iNow+1)%3+'.jpg");
4)对用户一些影响当前变换的操作进行约束
分散效果重点:
每一个小块的transform:translate('+(aSpan[i].offsetLeft-oBox.offsetWidth/2)+'px,'+(aSpan[i].offsetTop -oBox.offsetHeight/2)+'px) rotateX('+rnd(-180,180)+'deg) rotateY('+rnd(-180,180)+'deg) scale(1.4)
每个小块的transform: aSpan[i].style.transform='perspective(800px) rotateY(-180deg)'
transition: aSpan[i].style.transition='500ms all ease '+(aSpan[i].c+aSpan[i].r)*200+'ms'
第四个参数代表等待运动的时间,故生成依次轮流翻转的效果
document.onmouseover=function(){
当前那个元素的transform:rotateZ(90deg)
}
依次出现的效果:
oBj.style.transform ='rotateY('+i*360/N+'deg) translateZ(300px)'
布局如下:
<div id="box">
<div id="page">
<div class="front"></div>
<div class="back"></div>
</div>
<div id="page2"></div>
</div>
#page是当前的图片 ,#page2是将要变换的图片,其中#page的front背景图片和#box的背景图片拼成一张当前显示的图片,#page的back背景图片和#page2的背景图片拼成一张即将要换的图片