佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 原生ajax瀑布流demo分享(必看篇)

原生ajax瀑布流demo分享(必看篇)

熱門標(biāo)簽:銀行業(yè)務(wù) 阿里云 Linux服務(wù)器 團(tuán)購網(wǎng)站 電子圍欄 科大訊飛語音識別系統(tǒng) Mysql連接數(shù)設(shè)置 服務(wù)器配置

最近聽朋友們說起瀑布流挺多的,自己就去研究下了,一個簡單的原生demo,分享給大家...

簡單分為三個文檔,有詳細(xì)的注釋:img;ajax.php;demo.php

其中img文件夾中放入圖片 1.jpg;2.jpg;3.jpg....

ajax.php頁面

?php
  //模擬從數(shù)據(jù)庫讀取數(shù)據(jù)
  $arr = array();
  $op = opendir('./img');  //打開目錄

  //循環(huán)讀取目錄
  while (($file = readdir($op)) !== false) {
    //過濾點(diǎn)和點(diǎn)點(diǎn)
    if ($file == '.' || $file == '..') {
      continue;
    }
    $arr[] = $file;
  }
  closedir($op);  //關(guān)閉目錄
  echo json_encode($arr);

demo.html頁面

!DOCTYPE html>
html lang="en">
head>
  meta charset="UTF-8">
  title>瀑布流/title>
  style>
    li{
      list-style: none;
      float: left;
      margin:4px;
    }
    img{
      border:4px solid black;
    }
  /style>
/head>
body>
  ul id="ul">
    !-- li>img src="./img/1.jpg" height="300" alt="">/li> -->
  /ul>
/body>
script>
  //找對象
  var ul = document.getElementById('ul');

  //拿數(shù)據(jù)
  function getData()
  {
    var ajax = new XMLHttpRequest();
    ajax.open('get', 'ajax.php', true);
    ajax.send();
    ajax.onreadystatechange = function()
    {
      if (ajax.readyState == 4  ajax.status == 200) {
        var res = ajax.responseText;
        //處理結(jié)果
        var obj = JSON.parse(res);
        for (var k in obj) {
          // obj[k];
          //創(chuàng)建節(jié)點(diǎn)
          var li = document.createElement('li');
          li.innerHTML = 'img src="./img/'+obj[k]+'" height="300" />';
          ul.appendChild(li);
        }
      }
    }
  }
  getData();

  var timer;
  //判斷滾動條的高度,加載第二批文件
  window.onscroll = function()
  {
    //獲取三高
    var zGao = document.documentElement.scrollHeight;//總高度
    var lGao = document.documentElement.clientHeight;//瀏覽器可用高度
    var gGao = document.body.scrollTop || document.documentElement.scrollTop;//滾出去的高度
    // console.log(zGao, lGao, gGao);

    document.title = zGao + '_' + lGao + '_' + gGao;

    if (zGao - lGao - gGao  500) {
      clearTimeout(timer);
      //用一次性定時器解決連續(xù)加載的問題
      timer = setTimeout(function(){
        getData();
      }, 200)
    }
  }
/script>
/html>

以上這篇原生ajax瀑布流demo分享(必看篇)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 原生js實現(xiàn)移動端瀑布流式代碼示例
  • 原生JS實現(xiàn)響應(yīng)式瀑布流布局
  • AJAX實現(xiàn)瀑布流布局

標(biāo)簽:蚌埠 大理 衢州 衡水 棗莊 江蘇 萍鄉(xiāng) 廣元

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《原生ajax瀑布流demo分享(必看篇)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    曲沃县| 朔州市| 拉孜县| 长岛县| 哈尔滨市| 祁东县| 灌南县| 沁水县| 巴塘县| 二连浩特市| 克山县| 囊谦县| 巩义市| 迁西县| 桐柏县| 天津市| 长寿区| 中宁县| 清河县| 绥滨县| 乐平市| 鹤壁市| 天峨县| 河池市| 巩义市| 开平市| 德江县| 苍梧县| 德保县| 福建省| 厦门市| 鄂温| 余姚市| 西盟| 济阳县| 桃园市| 汝南县| 乌兰浩特市| 宁乡县| 吴旗县| 孝义市|