欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

3D立体动画效果侧导航

程序员文章站 2022-06-27 14:23:56
效果图 index.html index

效果图

3D立体动画效果侧导航

index.html

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>index</title>
    <link rel="stylesheet" href="css/style.css">
</head>

<body>

<div class="nav-main">
    <div class="nav-box">
        <!-- 一级菜单 -->
        <div class="nav">
            <ul class="nav-ul">
                <li><a href="#" class="home"><span>首页</span></a></li>
                <li><a href="#" class="develop"><span>h5开发</span></a></li>
                <li><a href="#" class="wechat"><span>微信推广</span></a></li>
                <li><a href="#" class="case"><span>项目案例</span></a></li>
                <li><a href="#" class="news"><span>信息资讯</span></a></li>
                <li><a href="#" class="contact"><span>关于我们</span></a></li>
            </ul>
        </div>
        <!-- 二级菜单 -->
        <div class="nav-slide">
            <div class="nav-slide-o"></div>
            <div class="nav-slide-o">
                <ul>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                    <li><a href="#"><span>微信开发</span></a></li>
                </ul>
            </div>
            <div class="nav-slide-o">
                <ul>
                    <li><a href="#"><span>微信关注</span></a></li>
                    <li><a href="#"><span>微信关注</span></a></li>
                    <li><a href="#"><span>微信关注</span></a></li>
                    <li><a href="#"><span>微信关注</span></a></li>
                    <li><a href="#"><span>微信关注</span></a></li>
                    <li><a href="#"><span>微信关注</span></a></li>
                    <li><a href="#"><span>微信关注</span></a></li>
                    <li><a href="#"><span>微信关注</span></a></li>
                </ul>
            </div>
            <div class="nav-slide-o">
                <ul>
                    <li><a href="#"><span>网站设计</span></a></li>
                    <li><a href="#"><span>网站设计</span></a></li>
                    <li><a href="#"><span>网站设计</span></a></li>
                    <li><a href="#"><span>网站设计</span></a></li>
                    <li><a href="#"><span>网站设计</span></a></li>
                    <li><a href="#"><span>网站设计</span></a></li>
                    <li><a href="#"><span>网站设计</span></a></li>
                    <li><a href="#"><span>网站设计</span></a></li>
                    <li><a href="#"><span>网站设计</span></a></li>
                </ul>
            </div>
            <div class="nav-slide-o">
                <ul>
                    <li><a href="#"><span>企业建站</span></a></li>
                    <li><a href="#"><span>企业建站</span></a></li>
                    <li><a href="#"><span>企业建站</span></a></li>
                    <li><a href="#"><span>企业建站</span></a></li>
                    <li><a href="#"><span>企业建站</span></a></li>
                    <li><a href="#"><span>企业建站</span></a></li>
                    <li><a href="#"><span>企业建站</span></a></li>
                    <li><a href="#"><span>企业建站</span></a></li>
                    <li><a href="#"><span>企业建站</span></a></li>
                </ul>
            </div>
        </div>
    </div>
</div>

<script src='https://libs.baidu.com/jquery/1.10.2/jquery.min.js'></script>
<script src='js/script.js'></script>
</body>
</html>

style.css

@charset "utf-8";
  html,body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,p,blockquote,th,td,textarea {
  margin:0;
  padding:0;
  font-size:14px;
  line-height:24px;
  color:#000;
  font-family:microsoft yahei,verdana,tahoma
}
ol,ul,li {
  list-style:none;
  line-height:22px
}
ol,ul {
  zoom:1
}
h1,h2,h3,h4,h5,h6 {
  font-size:100%
}
img {
  border:none;
  max-width:100%
}
a,a:link,a:visited {
  cursor:pointer;
  text-decoration:none
}
a:hover {
  cursor:pointer
}
.table {
  border-collapse:collapse;
  border-spacing:0
}
.table td {
  border:solid 1px #666
}
.clear {
  clear:both;
  float:none;
  overflow:hidden;
  height:0;
  font-size:0
}
.clearfix:after {
  clear:both;
  display:block;
  visibility:hidden;
  height:0;
  line-height:0;
  content:"."
}
.clearfix {
  zoom:1
}
* {
  -webkit-box-sizing:border-box;
  -moz-box-sizing:border-box;
  box-sizing:border-box
}
:after,:before {
  -webkit-box-sizing:border-box;
  -moz-box-sizing:border-box;
  box-sizing:border-box
}
.font {
  font:14px/24px "comic sans ms"
}
:focus {
  outline:none
}
.css3pie {
  -webkit-border-radius:5px;
  -moz-border-radius:5px;
  border-radius:5px;
  behavior:url(css3pie/pie.htc)
}
body {
  font-size:14px;
  font-family:黑体-简,黑体,微软雅黑,arial,gotham,helvetica neue,helvetica,sans-serif;
  width:100%;
  margin:0 auto;
  background-color:#313131;
  overflow-x:hidden
}
.wrap {
  width:100%;
  height:1000px
}
.wrap p {
  font-size:48px;
  text-align:center;
  color:#fff;
  padding-top:280px;
  line-height:60px
}
.logo {
  text-align:center;
  vertical-align:middle;
  background:#357dd7;
  margin-left:45%;
  top:20%;
  z-index:11;
  width:240px;
  height:240px;
  overflow:hidden;
  position:relative
}
.logo:hover {
  box-shadow:0 0 10px #333
}
.logo h1 {
  display:table-cell;
  vertical-align:middle;
  width:240px;
  height:240px
}
.logo a {
  width:240px;
  height:240px;
  overflow:hidden
}
.logo a:before {
  content:'';
  position:absolute;
  left:-230%;
  top:0;
  width:200%;
  height:120%;
  background:#1f415f;
  z-index:1;
  transform:skew(30deg,0);
  -webkit-transform:skew(30deg,0);
  -ms-transform:skew(30deg,0);
  -moz-transform:skew(30deg,0);
  -o-transform:skew(30deg,0);
  transition:all .5s;
  -moz-transition:all .5s;
  -webkit-transition:all .5s;
  -o-transition:all .5s
}
.logo a:hover {
  background:#357dd7
}
.logo a:hover:before {
  left:-60px
}
.logo img {
  position:relative;
  z-index:1
}
.nav-main {
  position:fixed;
  top:0;
  z-index:12;
  height:100%;
  width:100px;
  color:#fff;
  background:#111213
}
.nav-main a {
  color:#fff
}
.nav-box {
  position:relative;
  perspective:200px;
  -webkit-perspective:200px;
  transform-style:preserve-3d;
  -webkit-transform-style:preserve-3d;
  height:100%;
  z-index:99
}
.nav-ul li a {
  display:block;
  width:100px;
  height:100px;
  overflow:hidden;
  text-align:center;
  position:relative;
  transition:all .5s;
  -moz-transition:all .5s;
  -webkit-transition:all .5s;
  -o-transition:all .5s
}
.nav-ul li a:before {
  content:'';
  position:absolute;
  left:-240px;
  top:0;
  width:200px;
  height:100%;
  background:#629feb;
  z-index:1;
  transform:skew(30deg,0);
  -webkit-transform:skew(30deg,0);
  -ms-transform:skew(30deg,0);
  -moz-transform:skew(30deg,0);
  -o-transform:skew(30deg,0);
  transition:all .5s;
  -moz-transition:all .5s;
  -webkit-transition:all .5s;
  -o-transition:all .5s
}
.nav-ul li a:hover {
  background:#357dd7
}
.nav-ul li a:hover:before {
  left:-30px
}
.nav-ul li a:after {
  content:'';
  position:absolute;
  width:100%;
  height:30px;
  left:0;
  top:20px;
  z-index:1
}
.nav-ul li a span {
  display:block;
  margin-top:60px;
  perspective:;
  position:relative;
  z-index:1
}
.nav-slide {
  position:fixed;
  left:100px;
  top:0;
  width:240px;
  height:100%;
  background:#252829;
  transform:rotatey(120deg);
  -webkit-transform:rotatey(120deg);
  -moz-transform:rotatey(120deg);
  -o-transform:rotatey(120deg);
  -ms-transform:rotatey(120deg);
  z-index:99;
  visibility:hidden;
  transform-origin:0 0;
  -webkit-transform-origin:0 0;
  -moz-transform-origin:0 0;
  -o-transform-origin:0 0;
  -ms-transform-origin:0 0;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  transition:all .5s;
  -webkit-transition:all .5s;
  -moz-transition:all .5s;
  -o-transition:all .5s;
  transition-timing-function:cubic-bezier(.08,.72,.71,.96);
  -webkit-transition-timing-function:cubic-bezier(.08,.72,.71,.96)
}
.nav-slide.hover {
  transform:rotatey(0deg);
  -webkit-transform:rotatey(0deg);
  -moz-transform:rotatey(0deg);
  -o-transform:rotatey(0deg);
  -ms-transform:rotatey(0deg);
  z-index:15;
  visibility:visible
}
.nav-slide-o li a {
  line-height:50px;
  display:block;
  padding:0 20px;
  font-size:14px;
  overflow:hidden;
  text-align:left;
  position:relative;
  transition:all .5s;
  -webkit-transition:all .5s;
  -moz-transition:all .5s;
  -o-transition:all .5s
}
.nav-slide-o li a:before {
  content:'';
  position:absolute;
  left:-230%;
  top:0;
  width:200%;
  height:100%;
  background:#629feb;
  z-index:1;
  transform:skew(30deg,0);
  -webkit-transform:skew(30deg,0);
  -moz-transform:skew(30deg,0);
  -o-transform:skew(30deg,0);
  -ms-transform:skew(30deg,0);
  transition:all .5s;
  -webkit-transition:all .5s;
  -moz-transition:all .5s;
  -o-transition:all .5s
}
.nav-slide-o li a:hover {
  background:#357dd7
}
.nav-slide-o li a:hover:before {
  left:-60px
}
.nav-slide-o li a span {
  position:relative;
  z-index:1
}
.nav-slide-o {
  display:none
}

script.js

$(function(){
    var thistime;
    $('.nav-ul li').mouseleave(function(even){
            thistime    =   settimeout(thismouseout,1000);
    })

    $('.nav-ul li').mouseenter(function(){
        cleartimeout(thistime);
        var thisub  =   $('.nav-ul li').index($(this));
        if($.trim($('.nav-slide-o').eq(thisub).html()) != "")
        {
            $('.nav-slide').addclass('hover');
            $('.nav-slide-o').hide();
            $('.nav-slide-o').eq(thisub).show();
        }
        else{
            $('.nav-slide').removeclass('hover');
        }
        
    })
    
    function thismouseout(){
        $('.nav-slide').removeclass('hover');
    }
     
    $('.nav-slide').mouseenter(function(){
        cleartimeout(thistime);
        $('.nav-slide').addclass('hover');
    })
    $('.nav-slide').mouseleave(function(){
        $('.nav-slide').removeclass('hover');
    })

})