錘子商城首頁banner圖鼠標跟隨及視覺差效果

我發現如今不少網站都使用了這種效果,好比說錘子官網、elementui官網、秒味課堂等,不僅僅有鼠標跟隨的效果,隨着鼠標的移動還有視覺差的效果,看起來很高大上的技術,其實實現起來很簡單,主要利用css3的transform-style和persperctive屬性。css

廢話很少說直接上代碼:html

html:html5

複製代碼
<div class="perspective">
        <div class="preserve3d">
            <span class="preserve3d_img"></span>
            <span class="preserve3d_text">以傲慢與偏執<br/>回敬傲慢與偏見</span>
        </div>
</div>
複製代碼

css:css3

關鍵設置:git

   一、爲外層容器設置perspective屬性,這個屬性值能夠自定義能夠是數值、top/bottom等github

二、把你想要設置爲視覺差的元素設置爲絕對定位,而且添加transform:tanslateZ(deg)屬性

複製代碼
    * {
        font-family: "Microsoft YaHei";
        transition: all .3s;
        -webkit-transition: all .3s;
        transition-timing-function: linear;
        -webkit-transition-timing-function: linear;
    }

    .perspective {
        perspective: 800px;
    }

    .preserve3d {
        position: relative;
        width: 600px;
        height: 300px;
        margin: 100px auto;
        background: url("http://static.smartisanos.cn/index/img/store/home/banner-3d-item-1-box-1_61bdc2f4f9.png") center no-repeat;
        background-size: 100% 100%;
        border-radius: 10px;
        transform-style: preserve-3d;
    }

    .preserve3d_img {
        position: absolute;
        width: 100%;
        height: 100%;
        bottom: 11px;
        left: 0;
        background: url("http://static.smartisanos.cn/index/img/store/home/banner-3d-item-1-box-3_8fa7866d59.png") center no-repeat;
        background-size: 95% 100%;

        -webkit-transform: translateZ(60px);
    }

    .preserve3d_text {
        position: absolute;
        top: 20%;
        right: 10%;
        font-size: 30px;
        color: #fff;
        text-align: right;
        font-weight: lighter;

        -webkit-transform: translateZ(40px);
    }
複製代碼

js:web

複製代碼
 $('.preserve3d').on('mouseenter', function() {
          var thisPX = $(this).offset().left;
          var thisPY = $(this).offset().top;
          var boxWidth = $(this).outerWidth();
          var boxHeight = $(this).outerHeight();
          $(this).addClass("smart_3d");

          })
          .on('mousemove', function(event) {
          var mouseX = event.pageX - thisPX;
          var mouseY = event.pageY - thisPY;
          var X = mouseX - boxWidth/2;
          var Y = boxHeight/2 - mouseY;
          $(this).css({
            "-webkit-transform": "rotateY(" + X / 50 + "deg) " + "rotateX(" + Y / 50 + "deg)"
          });
          })
          .on('mouseleave', function() {
            $(this).removeClass("smart_3d");
            $(this).css({
              "-webkit-transform": "rotateY(0deg) rotateX(0deg)"
            })

          })     
複製代碼

ok,就是這麼簡單~還能夠直接作成jQuery插件,具體參考: https://github.com/tian0o0/html5/tree/master/smart_banner網站

相關文章
相關標籤/搜索