web299.com
全部
教育
语言/资格考试
法律
互联网
政务民生
Word模板
Excel模板
PPT模板
网页特效
小程序模板
网站模板
首页
教育
语言/资格考试
法律
互联网
政务民生
Word模板
Excel模板
PPT模板
网页特效
小程序模板
网站模板
当前位置:
首页
>
网页特效
>
动画效果
纯CSS3超酷书架样式404页面动画特效
分类:
动画效果
日期:
2024-05-14
点击(0)
评论(0)
演 示
免费下载
简介
##### HTML结构 该404页面使用一个nav元素来作为导航。 ```html
Home page
About us
Contact
F.A.Q.
Error 404
糟糕,您要找的书籍不在书架中。。。
``` ##### CSS样式 整个页面使用flexbox来进行布局。 ```html body { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; margin: 0; padding: 0; background-color: #446072; font-family: "Microsoft YaHei",sans-serif; color: white; -webkit-box-pack: center; -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -webkit-align-items: center; -ms-flex-align: center; align-items: center; -webkit-box-orient: vertical; -webkit-box-direction: normal; -webkit-flex-direction: column; -ms-flex-direction: column; flex-direction: column; overflow: hidden; } ``` .shelf元素是书架,里面是一些导航按钮。它使用相对定位,为了制作开门的3D动画效果,为它设置了perspective透视度。 ```html .shelf { position: relative; width: 30rem; height: 14rem; border: 0.5rem solid #374d5b; border-radius: 0.5rem; background-color: rgba(255, 255, 255, 0.1); -webkit-perspective: 130rem; perspective: 130rem; box-shadow: inset 0 0 2rem rgba(0, 0, 0, 0.2); } ``` .door是左右两扇书架门,它的:before伪元素用来制作门的手柄。 ```html .door { position: absolute; width: 14.8rem; height: 14rem; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; box-sizing: border-box; padding: 1rem; background-color: #374d5b; -webkit-box-align: center; -webkit-align-items: center; -ms-flex-align: center; align-items: center; box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3); } .door::before { width: 1.5rem; height: 1.5rem; border-radius: 50%; background-color: rgba(0, 0, 0, 0.1); content: ""; } ``` 左侧的门的transform-origin被设置在0 0 0位置,及左上角位置,并执行leftDoorOpen和leftDoorFlap两个帧动画。 ```html .door.left { border-radius: 0 0.75rem 0.75rem 0; -webkit-box-pack: end; -webkit-justify-content: flex-end; -ms-flex-pack: end; justify-content: flex-end; -webkit-animation: leftDoorOpen 3.5s ease-out forwards 1s, leftDoorFlap 15s linear infinite forwards 9s; animation: leftDoorOpen 3.5s ease-out forwards 1s, leftDoorFlap 15s linear infinite forwards 9s; -webkit-transform-origin: 0 0 0; transform-origin: 0 0 0; } @keyframes leftDoorOpen { 60% {-webkit-transform: rotateY(-115deg);transform: rotateY(-115deg)} 100% {-webkit-transform: rotateY(-110deg);transform: rotateY(-110deg)} } @keyframes leftDoorFlap { 0% { -webkit-transform: rotateY(-110deg); transform: rotateY(-110deg)} 5% {-webkit-transform: rotateY(-115deg);transform: rotateY(-115deg)} 15% {-webkit-transform: rotateY(-107deg);transform: rotateY(-107deg)} 25% {-webkit-transform: rotateY(-113deg);transform: rotateY(-113deg)} 30% {-webkit-transform: rotateY(-110deg);transform: rotateY(-110deg)} 100% {-webkit-transform: rotateY(-110deg);transform: rotateY(-110deg)} } ``` 右侧的门的转换圆点设置在100% 0 0位置,并执行rightDoorOpen和rightDoorFlap两个帧动画。 ```html .door.right { right: 0; border-radius: 0.75rem 0 0 0.75rem; -webkit-animation: rightDoorOpen 3s ease-out forwards 1.5s, rightDoorFlap 10s linear infinite forwards 8s; animation: rightDoorOpen 3s ease-out forwards 1.5s, rightDoorFlap 10s linear infinite forwards 8s; -webkit-transform-origin: 100% 0 0; transform-origin: 100% 0 0; } @keyframes rightDoorOpen { 60% {-webkit-transform: rotateY(125deg);transform: rotateY(125deg)} 100% {-webkit-transform: rotateY(120deg);transform: rotateY(120deg)} } @keyframes rightDoorFlap { 0% { -webkit-transform: rotateY(120deg); transform: rotateY(120deg)} 5% {-webkit-transform: rotateY(125deg);transform: rotateY(125deg)} 15% {-webkit-transform: rotateY(117deg);transform: rotateY(117deg)} 25% {-webkit-transform: rotateY(123deg);transform: rotateY(123deg)} 30% {-webkit-transform: rotateY(120deg);transform: rotateY(120deg)} 100% {-webkit-transform: rotateY(120deg);transform: rotateY(120deg)} } ``` 几个链接元素被制作为圆角矩形,并使用transform函数将它们旋转和移动到相应的位置。.not-found元素还会执行一个闪烁动画bookFadeOut。 ```html .book { position: absolute; box-sizing: border-box; padding: 0.8rem 4rem 0.8rem 2rem; border-radius: 0.25rem; background-color: rgba(255, 255, 255, 0.1); color: white; font-size: 1rem; text-transform: uppercase; letter-spacing: 0.1rem; cursor: pointer; box-shadow: inset 0 0 0.75rem rgba(255, 255, 255, 0.1); } .book.home-page { -webkit-transform: rotate(-90deg) translate(-12.4rem, 3rem); transform: rotate(-90deg) translate(-12.4rem, 3rem); -webkit-transform-origin: 0; transform-origin: 0; } .book.about-us { -webkit-transform: rotate(-100deg) translate(-13.4rem, 6.1rem); transform: rotate(-100deg) translate(-13.4rem, 6.1rem); -webkit-transform-origin: 0; transform-origin: 0; } .book.contact { right: 2rem; bottom: 0.2rem; border-radius: 0.3rem 0 0 0.3rem; } .book.faq { right: 0.8rem; bottom: 3.3rem; border-radius: 0.3rem 0 0 0.3rem; } .book.not-found { width: 12rem; height: 3.5rem; border: 1px dashed rgba(255, 255, 255, 0.3); background-color: transparent; -webkit-transform: rotate(-90deg) translate(-12rem, 13rem) scale(1); transform: rotate(-90deg) translate(-12rem, 13rem) scale(1); -webkit-transform-origin: 0; transform-origin: 0; cursor: default; -webkit-animation: bookFadeOut 1s 3s infinite forwards; animation: bookFadeOut 1s 3s infinite forwards; } ```
相关推荐
html5浪漫粒子表白文字特效
SlidesJS幻灯片特效
html5瀑布流相册特效
css3 svg实现的情人节表白鲜花动画特效
t-scroll.js基于ES6的DOM元素,过渡动画库插件
纯js写省市区三级联动效果
广告
广告