css3+js翻页效果三:书本翻页

css样式是酱紫的:
*{margin:0; padding:0}
body,html{
    /*防止抖动*/
    overflow: hidden;
}
#box{ 
   width:700px;
    height:400px;
    background: url("img/0.jpg")
    no-repeat;
    margin:100px auto;
    position:relative;
}
#box .page{
    /*在box的右半部分*/
    width: 50%;
    height: 100%;
    top:0;
    right:0;
    position: absolute;
    /*开启3d模式*/
    transform-style: preserve-3d; 
   /*设定旋转中心*/
    transform-origin: left center;
    transition:1s all ease; 
   z-index:2; 
   /*初始化*/ 
   transform:perspective(800px) rotateY(0deg);
}
#box .page div{
    width:100%;
    height:100%;
    position:absolute;
    left:0;
    top:0;
}
#box .page .front{
    /*显示图片的右半部分*/
    background: url("img/0.jpg") right top no-repeat;
    /*不显示背面*/
    backface-visibility: hidden; 
   /*层级比背面高*/ 
   z-index:2;
}
#box .page .back{
    background:url("img/1.jpg") left top no-repeat;
    z-index: 1;
   transform: scale(-1,1);
}
#box .page2{
    width:50%;
    height:100%;
    position:absolute;
    right:0;
    top:0;
    background: url("img/1.jpg") right top no-repeat;
    z-index:1;
}
这里面有几个比较重要的css3知识点:

1、transform-style:preserve-3d;开启3d模式,这样才真正的是3d效果,后面的
backface-visibility: hidden;
z-index:2;才会有三维效果
transform-style:flat; 默认是平面

2、 backface-visibility: hidden; 是背面不可见
backface-visibility: visible; 是背面可见

3、transform: scale(-1,1); 水平翻转
scale(x,y)定义 2D 缩放转换。
scale3d(x,y,z)定义 3D 缩放转换。
scaleX(x)通过设置 X 轴的值来定义缩放转换。
scaleY(y)通过设置 Y 轴的值来定义缩放转换。
scaleZ(z)通过设置 Z 轴的值来定义 3D 缩放转换。
rotate(angle)定义 2D 旋转,在参数中规定角度。

4、 transform-origin: left center;
transform-origin: x-axis y-axis z-axis;
x-axis:定义视图被置于 X 轴的何处。可能的值:
left
center
right
length
%
y-axis:定义视图被置于 Y 轴的何处。可能的值:
top
center
bottom
length
%
z-axis:定义视图被置于 Z 轴的何处。可能的值:
length

5、transform:perspective
perspective: number|none;
number:元素距离视图的距离,以像素计。
none 默认值。与 0 相同。不设置透视。
transform:rotate
rotate(angle)
定义 2D 旋转,在参数中规定角度。

rotate3d(x,y,z,angle)
定义 3D 旋转。

rotateX(angle)
定义沿着 X 轴的 3D 旋转。

rotateY(angle)
定义沿着 Y 轴的 3D 旋转。

rotateZ(angle)
定义沿着 Z 轴的 3D 旋转。

接下来是简单的布局:
<div id="box">
    <div class="page">
        <div class="front"></div>
        <div class="back"></div>
    </div>
    <div class="page2"></div>
</div>
最后是js部分的代码:
document.addEventListener('DOMContentLoaded',function(){
    var oBox = document.getElementById('box');
    var oPage  = document.querySelector('.page');
    var oPage2  = document.querySelector('.page2');
    var oFront  = document.querySelector('.front');
    var oBack  = document.querySelector('.back');
    var iNow = 0;
    var bReady = true;
    oBox.onclick = function(){
        if(bReady==false) {
            return;
        }
        bReady = false;
        iNow++;
        oPage.style.transition = '1s all ease';
        oPage.style.WebkitTransform = 'perspective(800px) rotateY(-180deg)';    
};
    oPage.addEventListener('transitionend',function(){
        //1.瞬间拉回
        oPage.style.transition = 'none';
        oPage.style.WebkitTransform = 'perspective(800px) rotateY(0deg)';
        //2.换图
        oBox.style.background = 'url("img/'+(iNow%3)+'.jpg") no-repeat';
        oFront.style.background = 'url("img/'+(iNow%3)+'.jpg") right top no-repeat';
       oBack.style.background = 'url("img/'+((iNow+1)%3)+'.jpg") left top no-repeat';
        oPage2.style.background = 'url("img/'+((iNow+1)%3)+'.jpg") right top no-repeat';
        bReady = true;
    },false);
},false);

这就是结果啦。效果就像是翻书一样:
给个图:

3872133-f8dffb8add25df1f.png
Paste_Image.png
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值