判断上下左右触发的hover的特效

2017-02-24  本文已影响56人  程小E

html:

<!DOCTYPE HTML>
<html lang="en-US">
<head>
  <meta charset="UTF-8">
  <title>label</title>
  <script type="text/javascript" src="http://runjs.cn/js/sandbox/jquery/jquery-1.8.2.min.js"></script>
</head>
<body>
  <div id="main">
    <div class="items">
      <div class="img">
        ![](https://img.haomeiwen.com/i3760171/da4d579ff00ac540.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        <div class="desc">这货是鸣人、这货是鸣人、这货是鸣人、这货是鸣人、这货是鸣人、这货是鸣人、这货是鸣人、</div>
      </div>
      <div class="title">鸣人</div>
    </div>
    
    <div class="items">
      <div class="img">
        ![](https://img.haomeiwen.com/i3760171/30dc05067d3b20da.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        <div class="desc">这货是鸣人他爹、这货是鸣人他爹、这货是鸣人他爹、这货是鸣人他爹、这货是鸣人他爹、</div>
      </div>
      <div class="title">鸣人他爹</div>
    </div>
    
    <div class="items">
      <div class="img">
        ![](https://img.haomeiwen.com/i3760171/a4051e45e7804a00.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        <div class="desc">这货是我爱罗、这货是我爱罗、这货是我爱罗、这货是我爱罗、这货是我爱罗、</div>
      </div>
      <div class="title">我爱罗</div>
    </div>
    
    <div class="items">
      <div class="img">
        ![](https://img.haomeiwen.com/i3760171/73a8eb9137a0de2e.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        <div class="desc">这货是斑、这货是斑、这货是斑、这货是斑、这货是斑、这货是斑、这货是斑、</div>
      </div>
      <div class="title">斑</div>
    </div>
  
    <div class="items">
      <div class="img">
        ![](https://img.haomeiwen.com/i3760171/da4d579ff00ac540.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        <div class="desc">这货是鸣人、这货是鸣人、这货是鸣人、这货是鸣人、这货是鸣人、这货是鸣人、这货是鸣人、</div>
      </div>
      <div class="title">鸣人</div>
    </div>
    
    <div class="items">
      <div class="img">
        ![](https://img.haomeiwen.com/i3760171/30dc05067d3b20da.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        <div class="desc">这货是鸣人他爹、这货是鸣人他爹、这货是鸣人他爹、这货是鸣人他爹、这货是鸣人他爹、</div>
      </div>
      <div class="title">鸣人他爹</div>
    </div>
    
    <div class="items">
      <div class="img">
        ![](https://img.haomeiwen.com/i3760171/a4051e45e7804a00.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        <div class="desc">这货是我爱罗、这货是我爱罗、这货是我爱罗、这货是我爱罗、这货是我爱罗、</div>
      </div>
      <div class="title">我爱罗</div>
    </div>
    
    <div class="items">
      <div class="img">
        ![](https://img.haomeiwen.com/i3760171/73a8eb9137a0de2e.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
        <div class="desc">这货是斑、这货是斑、这货是斑、这货是斑、这货是斑、这货是斑、这货是斑、</div>
      </div>
      <div class="title">斑</div>
    </div>
  </div>
</body>
</html>

css

*{
    margin:0px;
    padding:0px;
    font:12px/2 微软雅黑;
}
#main{
    width:960px;
    margin:20px auto;
}
.items{
    width:216px;
    border:1px solid #dcdcdc;
    overflow:hidden;
    float:left;
    margin:15px 15px 0 0;
    background-color:#fff;
}
.items .img{
    height:300px;
    overflow:hidden;
    position:relative;
}
.items .desc{
    height:270px;
    width:186px;
    padding:15px;
    position:absolute;
    top:-300px;
    left:0px;
    color:#fff;
    background-image:url();
}
.items .title{
    border-top:1px solid #dcdcdc;
    padding:7px 14px;
}

JS(重点)

/**
 * 效果来源于 http://www.jue.so/ 采用 KISSY 的 UI 实现
 * 以下是 jQuery 方法实现,当然原生 js 也不难实现、、
 */
$(function () {
  $(".items .img").hover(function (e) {
    var _this  = $(this), //闭包
        _desc  = _this.find(".desc").stop(true),
        width  = _this.width(), //取得元素宽
        height = _this.height(), //取得元素高
        left   = e.offsetX || e.originalEvent.layerX, //得到左边界
        top    = e.offsetY || e.originalEvent.layerY, //得到上边界
        right  = width - left, //计算出右边界
        bottom = height - top, //计算出下边界
        rect   = {}, //坐标对象,用于执行对应方法。
        _min   = Math.min(left, top, right, bottom), //得到最小值
        _out   = e.type == "mouseleave", //是否是离开事件
        spos   = {}; //起始位置

    rect[left] = function (epos) { //鼠从标左侧进入和离开事件
      spos = {"left": -width, "top": 0};
      if (_out) {
        _desc.animate(spos, "fast"); //从左侧离开
      } else {
        _desc.css(spos).animate(epos, "fast"); //从左侧进入
      }
    };

    rect[top] = function (epos) { //鼠从标上边界进入和离开事件
      spos = {"top": -height, "left": 0};
      if (_out) {
        _desc.animate(spos, "fast"); //从上面离开
      } else {
        _desc.css(spos).animate(epos, "fast"); //从上面进入
      }
    };

    rect[right] = function (epos) { //鼠从标右侧进入和离开事件
      spos = {"left": left,"top": 0};
      if (_out) {
        _desc.animate(spos, "fast"); //从右侧成离开
      } else {
         _desc.css(spos).animate(epos, "fast"); //从右侧进入
      }
    };
    
    rect[bottom] = function (epos) { //鼠从标下边界进入和离开事件
      spos = {"top": height, "left": 0};
      if (_out) {
        _desc.animate(spos, "fast"); //从底部离开
      } else {
        _desc.css(spos).animate(epos, "fast"); //从底部进入
      }
    };

    rect[_min]({"left":0, "top":0}); // 执行对应边界 进入/离开 的方法
  });
});
上一篇 下一篇

猜你喜欢

热点阅读