经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » CSS » 查看文章
css transform 翻页动画记录的实现_CSS教程_CSS
来源:jb51  时间:2020/12/8 9:20:03  对本文有异议

翻页问题场景

B和C是同一页(正反两面)

当想要翻页覆盖 A 时,B、C 需要同时翻页才能覆盖A,显示D。

B、C 不能写在同一个盒子里

错误例子:

  1. <div class="pagesBox A"></div>
  2. <div class="pagesBox">
  3. <div class="B"></div>
  4. <div class="C"></div>
  5. </div>
  6. <div class="pagesBox D"></div>

正确例子:

  1. <main>
  2. <div class="pagesBox A"></div>
  3. <div class="pagesBox B"></div>
  4. <div class="pagesBox C">
  5. <div>内容</div>
  6. </div>
  7.  
  8. <div class="pagesBox D"></div>
  9. </main>

为什么不使用一个盒子包裹 B、C,使他们翻转就可以了?

答案在下面。

B 需要设置

  1. .B{
  2. backface-visibility: hidden;
  3. }

backface-visibility: hidden; 这个属性是让B的 背面 隐藏。

并且让 B、C 重叠,使用绝对定位进行重叠。

C 需要设置

  1. .C > div{
  2. transform: rotateY(-180deg);
  3. }

因为正常内容是显示正面的,我们需要把 C 的内容翻转到背面。让它看起来像是 纸张 背面

回到上面的问题,为什么不使用一个盒子

因为包裹 B、C 的盒子进行翻转时,B 设置背面隐藏是无效的。只有让 B 进行翻转,才能让 B 的背面隐藏起来。显示背面的 C。

接着对B、C进行动画翻页。

  1. main{
  2. perspective: 1800;
  3. transform-style: preserve-3d;
  4. }
  5.  
  6. .B,.C{
  7. transition: transform 1s;
  8. &.On{
  9. transform: rotateY(180deg);
  10. }
  11. }

到此这篇关于css transform 翻页动画记录的实现的文章就介绍到这了,更多相关css翻页动画内容请搜索w3xue以前的文章或继续浏览下面的相关文章,希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号