div class="perspective-r"/div
div class="perspective-b"/div
div class="perspective-inner"透视效果元素/div
/div
二、Css代码:
.perspective-outer{
position:relative;
width:170px;/*要实现透视效果元素的宽度+透视距离*/
height:140px;/*要实现透视效果元素的高度+透视距离*/
}
.perspective-inner{
border:1px solid #f60;
height:118px;
width:148px;
background-color:#fff;
}
.perspective-r,
.perspective-b{
position:absolute;
width:0;
height:0;
}
.perspective-r{
right:0;
height:100px;/*要实现透视效果元素的高度(120px) - (border-top:20px)*/
border-left:20px solid #000;/*右边透视距离*/
border-top:20px solid #fff;/*下边透视距离*/
}
.perspective-b{
bottom:0;
width:150px;/*最外元素的宽度(170px) - border-left*/
border-left:20px solid #fff;
border-top:20px solid #000;
}
.perspective-outer定义高度和宽度,并相对定位,确保右边和下边的透视区域能定位的相应的位置,高度值和宽度值为要实现透视效果元素的高度加上相应的透视距离。.perspective-r只需设置高度值,其值为.perspective-outer的高度减去border-top,.perspective-b只需设置宽度值,其值为.perspective-outer的宽度减去border-left。.perspective-r的border-top和.perspective-b的border-left的width值决定透视角度。.perspective-r的border-left和.perspective-b的border-top的width值 决定透视距离。其中.perspective-r的border-top和.perspective-b的border-left的color为父元素的背景颜色,我这里的测试页面父元素为body,所以为白色。
三、后记
本文只是做一个简单得测试,其目的在于抛砖引玉。这种方法其实用性究竟有多大,咱姑且不论,但至少可以给我们一种解决问题的思路。希望此文能对你有所帮助。
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)原文:http://www.denisdeng.com/?p=474;