溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js實現櫥窗展示效果

發布時間:2020-09-10 01:37:19 來源:腳本之家 閱讀:176 作者:頑張ってちしじょ 欄目:web開發

本文實例為大家分享了js實現櫥窗展示的具體代碼,供大家參考,具體內容如下

思路

1、獲取需要的標簽

2、求出滾動條的長度(公式:滾動條長度 = ( 盒子的寬度 / 內容的寬度) * 盒子的寬度)

3、監聽鼠標按下事件:3 設置起始位置

4、監聽鼠標的移動:

4.1求出移動的位置
4.2判斷滾動條的位置(防超出)
4.3 移動滾動條、商品滾動(公式:內容走的距離 = (內容的長度 - 盒子的長度) / (盒子長度 - 滾動條的長度) * 滾動條走的距離);

5、監聽鼠標的離開事件:把鼠標的移動事件設置為無即可。

  <script>
    window.onload = function (){
      //1.獲取需要的標簽
      var box = document.getElementById("box");
      var box_top = box.children[0];
      var box_bottom = box.children[1];
      var mask = box_bottom.children[0];
      //2.獲取滾動條長度
      // 滾動條長度 = ( 盒子的寬度 / 內容的寬度) * 盒子的寬度
      var mask_length = (box.offsetWidth /box_top.offsetWidth) * box.offsetWidth;
      mask.style.width = mask_length + "px";
      //3.監聽鼠標按下的事件
      mask.onmousedown = function (event){
        var event = event || window.event;
        //3.1設置起始位置
        var beginX = event.clientX - mask.offsetLeft;
        //3.2 監聽鼠標的移動
        document.onmousemove =function (event){
          var event = event || window.event;
          //3.2.1求移動的位置
          var endX = event.clientX - beginX;

          //3.2.2處理邊界值
          if(endX < 0){
            endX = 0
          }else if(endX >= box.offsetWidth - mask.offsetWidth){
            endX = box.offsetWidth - mask.offsetWidth;
          }
          //3.2.3讓滾動條滾動
          mask.style.left = endX + "px";

          //3.2.4 讓商品隨著滾動
          //公式:內容走的距離 = (內容的長度 - 盒子的長度) / (盒子長度 - 滾動條的長度) * 滾動條走的距離
          var content_len = (box_top.offsetWidth - box.offsetWidth) / (box.offsetWidth - mask.offsetWidth) * endX;
          box_top.style.left = -content_len + "px";

          return false;
        };
        document.onmouseup = function (){
          document.onmousemove = null;
        }
      }
    }
</script>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女