亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

JS通過ajax + 多列布局 + 自動加載實現瀑布流效果

發布時間:2020-10-20 17:24:21 來源:腳本之家 閱讀:185 作者:des雷鋒 欄目:web開發

Ajax

•說明:本文效果是無限加載的,意思就是你一直滾動就會一直加載圖片出現,通過鼠標滾動距離來判斷的,所以不是說的那種加載一次就停了的那種,那種demo下次我會再做一次

css部分用的是html5+css3的新屬性,圖片會自動添加到每行的最頂端上去,而不是用js去判斷。去除了一些js計算的麻煩。

css部分:

 * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }
    body {
      background: #352323 url(images/a.png);
    }
    img {
      display: block;
    }
    section {
      max-width: 95%;
      margin: 0 auto;
      overflow: hidden;
      column-count: 5;
      column-gap: 0;
      column-fill: auto;
    }
    figure {
      border: 2px solid pink;
      margin: 0 5px 10px;
      break-inside: avoid;
      padding: 5px;
    }
    figure img {
      width: 100%;
    }
    figcaption {
      padding: 10px 0;
      text-align: center;
      font-weight: 900;
      color: #a77869;
    }

html部分:

通過js插入節點,因為后臺不知道多少張圖片

 <section>
    <!-- <figure>
      <img src="images/1.jpg" >
      <figcaption>往后余生,風雪是你</figcaption>
    </figure> -->
</section>

js有兩個部分,一個是我封裝的ajax函數,和一些判斷函數

第一部分

window.onload = function() {
    var section = document.getElementsByTagName('section')[0];
    //運行ajax函數;
    ajax('get', 'active.php', 'num=10', function(data) {
      //解析json對象
      let img_data = JSON.parse(data);
      console.log(img_data);
      //循環建多少圖片配多少標簽
      for (let i = 0; i < img_data.length; i++) {
        //建立figure標簽
        let figure = document.createElement('figure');
        //創建兩個子元素img和figcaption,并賦值
        let img = document.createElement('img');
        img.src = img_data[i];
        let figcaption = document.createElement('figcaption');
        figcaption.innerHTML = '往后余生,風雪是你';
        //插節點
        figure.appendChild(img);
        figure.appendChild(figcaption);
        section.appendChild(figure);
      }
    });
    document.onscroll = function() {
      var scrollTop = document.documentElement.scrollTop; //距離網頁高度
      console.log(scrollTop);
      // var ks = document.documentElement.clientHeight; //可是化窗口高度
      var ks = window.innerHeight || document.documentElement.clientHeight; //可是化窗口高度/兼容方法
      var ht = document.documentElement.offsetHeight; //html總高度
      // console.log(ht);
      if (scrollTop + 1 >= ht - ks) { //鼠標滾動的距離大于html總高度-窗口的距離(也就是html在可視窗口之下的總高度)時 觸發函數;
        //執行函數
        ajax('get', 'active.php', 'num=10', function(data) {
          //解析json對象
          let img_data = JSON.parse(data);
          console.log(img_data);
          //循環建多少圖片配多少標簽
          for (let i = 0; i < img_data.length; i++) {
            //建立figure標簽
            let figure = document.createElement('figure');
            //創建兩個子元素img和figcaption,并賦值
            let img = document.createElement('img');
            img.src = img_data[i];
            let figcaption = document.createElement('figcaption');
            figcaption.innerHTML = '往后余生,風雪是你';
            //插節點
            figure.appendChild(img);
            figure.appendChild(figcaption);
            section.appendChild(figure);
          }
        });
      }
    }
  };

第二部分:

/**
 * ajax封裝
 * @param {string} mehod請求數據方法
 * @param {string} url 請求地址
 * @param {string} data 請求參數
 * @param {[functiong]} success [請求成功之后執行的函數0]
 * @return {[none]} none
 */
function ajax(mehod, url, data, success) {
  var xhr = null;
  if (window.XMLHttpRequest) {
    xhr = new XMLHttpRequest();
  } else {
    xhr = new ActiveXObject("Microsoft.xmlhttp")
  }
  //如果有參數get方法需要拼接字符串url+?+data
  if (mehod === 'get' && data) {
    url += '?' + data;
  }
  //open方法
  xhr.open(mehod, url, true);
  //send方法
  if (mehod === 'get') {
    xhr.send();
  } else {
    xhr.setRequestHeader('content-type', 'application/x-www-form-urlencoded');
    xhr(data);
  }
  xhr.onreadystatechange = function() {
    if (xhr.readyState === 4 && xhr.status === 200) {
      success && success(xhr.responseText);
    }
  }

php后臺數據

因為主要功能偏向前端,所以后端就通過本地文件載入的

<?php 
header("Content-type:text/html;charset=utf-8");
$num = $_GET['num']; // api調用者傳遞的需要的圖片頁數 
$img = file("img.txt");
// var_dump($img);
$array_url = array();
for($i=0;$i<$num;$i++){
  $url = array_rand($img);
  array_push($array_url,$img[$url]);
}
$a = json_encode($array_url);
echo $a;

JS通過ajax + 多列布局 + 自動加載實現瀑布流效果

總結

以上所述是小編給大家介紹的JS通過ajax + 多列布局 + 自動加載來實現瀑布流效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節

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

AI

永顺县| 博野县| 镇康县| 舒兰市| 凌云县| 壤塘县| 镇雄县| 中山市| 渝中区| 鄂温| 墨江| 佛学| 江达县| 德钦县| 西华县| 河津市| 门源| 阿瓦提县| 怀安县| 鄂州市| 阳城县| 崇仁县| 喜德县| 抚顺县| 东源县| 彭山县| 宣威市| 安多县| 乌苏市| 山丹县| 大渡口区| 汝州市| 宜州市| 电白县| 潍坊市| 砀山县| 黎城县| 历史| 锦屏县| 明光市| 朝阳区|