通过CSS3 transform实现图片浏览的几种效果

html-css016

通过CSS3 transform实现图片浏览的几种效果,第1张

通过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的背景图片拼成一张即将要换的图片

利用css3来实现图片渐入效果。

下面是页面中的一段html:

<div class="features">

<div class="container">

<div class="inner feature">

<div class="content">

<h2 class="title"><img src="./imgs/title1.png" alt=""/></h2>

<p class="text">256位SSL加密安全连接,手机短信验证、谷歌两步验证、资金密码、邮箱验证四重验证保障安全,钱包分布式离线冷存储</p>

</div>

<img class="icon" src="./imgs/feature-icon1.png" alt=""/>

</div>

</div>

<div class="container middle">

<div class="inner feature">

<div class="content">

<h2 class="title"><img src="./imgs/title1.png" alt=""/></h2>

<p class="text">256位SSL加密安全连接,手机短信验证、谷歌两步验证、资金密码、邮箱验证四重验证保障安全,钱包分布式离线冷存储</p>

</div>

<img class="icon" src="./imgs/feature-icon2.png" alt=""/>

</div>

</div>

<div class="container">

<div class="inner feature">

<div class="content">

<h2 class="title"><img src="./imgs/title1.png" alt=""/></h2>

<p class="text">256位SSL加密安全连接,手机短信验证、谷歌两步验证、资金密码、邮箱验证四重验证保障安全,钱包分布式离线冷存储</p>

</div>

<img class="icon" src="./imgs/feature-icon3.png" alt=""/>

</div>

</div>

</div>

首先,需要先定位图片,把图片定位在渐入后最终停留的位置:

.feature .icon { position: absolute top: 100px

}

接着,利用css3的transform属性和translate()方法实现图片的偏移,还有就是将图片透明度设为0(即完全透明):

.feature .icon {position: absolute top: 100px transform: translate3d(0, 0, 150px) -ms-transform: translate3d(0, 150px, 0) -webkit-transform: translate3d(0, 150px, 0) -o-transform: translate3d(0, 150px, 0) -moz-transform: translate3d(0, 150px, 0) opacity: 0

}

这边需要加上各浏览器的前缀来兼容一些低版本浏览器。这些属性和方法的具体用法这边就细讲了。

然后,要用到的是css3的transition属性:

.feature .icon {position: absolute top: 100px transform: translate3d(0, 0, 150px) -ms-transform: translate3d(0, 150px, 0) -webkit-transform: translate3d(0, 150px, 0) -o-transform: translate3d(0, 150px, 0) -moz-transform: translate3d(0, 150px, 0) opacity: 0 transition: transform 1s ease 0s, opacity 1s ease 0s -moz-transition: -moz-transform 1s ease 0s, opacity 1s ease 0s -webkit-transition: -webkit-transform 1s ease 0s, opacity 1s ease 0s -o-transition: -o-transform 1s ease 0s, opacity 1s ease 0s -ms-transition: -ms-transform 1s ease 0s, opacity 1s ease 0s

}

transition属性是一个过渡属性,当元素从一种样式变换为另一种样式时为元素添加效果。

到这还没有效果。我们要达到的效果是:当网页往下滚动,图片出现或将要出现在视窗时,我们来触发这个过渡效果,就像大家看到的下面这张图片一样。这个做法就像图片的惰性加载,图片还没出现在视窗中时,先不加载,出现时再去加载图片,这样的效果就是用户访问页面的速度提升了。

这是一个数学问题。

当盒子模型和图片比例不一致时,要保持比例显示会出现两种情况:

一种是覆盖裁剪background-size: cover,即以短边为标准,图片缩放铺满整个容器的宽高,多出来的部分会裁剪掉;

另一种是完整包含background-size: contain,即以长边为标准,图片缩放完全展示在容器的内部,不足的部分会填充空白。

当盒子模型和图片比例不一致时,不保持比例显示可对图片进行拉伸以铺满整个容器的宽高background-size: 100% 100%;或对高进行拉伸background-size: auto 100%或对宽进行拉伸background-size: 100% auto ;或设置固定数值background-size: 20px 30px 。