圖片懶載入

来源:http://www.cnblogs.com/durenlong/archive/2017/06/28/7091777.html
-Advertisement-
Play Games

在圖片比較多的網站總會看見,當瀏覽到那個位置,就載入那的圖片。 ...


在圖片比較多的網站總會看見,當瀏覽到那個位置,就載入那的圖片。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			*{
				margin: 0;
				padding: 0;
			}
			img{
				display: block;
				width: 500px;
				height: 300px;
			}
			div{
				margin: 500px 0 0 40px;
			}
		</style>
	</head>
	<body>
		<div id="banner">
			<img data-src="image/01.jpeg">
			<img data-src="image/02.jpeg">
			<img data-src="image/03.jpeg">
			<img data-src="image/04.jpeg">
			<img data-src="image/05.jpg">
			<img data-src="image/06.png">
			<img data-src="image/07.png">
			<img data-src="image/08.png">
		</div>

		<script type="text/javascript">
			window.onload=function(){
				var banner=document.getElementById("banner"); 
				var imgs=banner.getElementsByTagName("img");
				 add();//頁面載入完成先執行一次
				function getTop(obj){ //寫一個方法獲取圖片距離top的值
					var t=0;      //定義一個保存top值的 變數
					while(obj){  //迴圈獲取每個父級定位的top值
						t+=obj.offsetTop;  //獲取傳入或改變父級定位的top值,當到大body的時候沒有 他的父級定位為null所以就停了
						obj=obj.offsetParent; //獲取obj的父級定位
						console.log(t)
						console.log(obj)
					}
					return t;
				}
				function add(){
					var S = document.documentElement.scrollTop || document.body.scrollTop; //獲取滑動條距top的值
					var H = window.innerHeight; //獲取顯示區域高度(只讀)
					for(var i=0;i<imgs.length;i++){  //迴圈圖片
						if((S+H) > getTop(imgs[i])){ 判斷圖片是否進入可視區域
							imgs[i].setAttribute("src",imgs[i].getAttribute("data-src")); //當進入的時候給src 賦值
						}
					}
				}
				
				window.onscroll=function(){ //每次滾動運行方法判斷
					add()
				}
			}
				
				
				
			
		</script>
	</body>
</html>

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、windows 1. 下載tomcat 2. 進入bin目錄,查看是否存在service.dat,如果沒有自行創建 3. 打開cmd,進入tomcat>bin目錄 說明:用法: service.bat install/remove [service_name] [/user username] ...
  • instanceof是Java的一個二元操作符(運算符),也是Java的保留關鍵字。它的作用是判斷其左邊對象是否為其右邊類的實例,返回的是boolean類型的數據。用它來判斷某個對象是否是某個Class類的實例。 用法: boolean result = object instanceof clas ...
  • 其實沒有完整的9天,就是連續每天花點時間,過程so frustrated,踩坑無數。。。下麵是學習過程的記錄 第1天 開始正式學習JavaEE,已完成: 1. Tomcat安裝; 2. Tomcat配置。完成了IIS占用的80埠停用,將Tomcat監聽埠改為80埠,然後修改hosts,增加解析 ...
  • 1.REST即表現層狀態傳遞(Representational [,rɛprɪzɛn'teʃnl] State Transfer,簡稱REST)。 (1)REST名詞解釋: 通俗來講就是資源在網路中以某種表現形式進行狀態轉移。分解開來: Resource:所指的不只是數據,而是數據和表現形式的組合; ...
  • 一 概述 1.什麼是UML? Unified Modeling Language,統一建模語言,用圖形化的語言展示事物的結構,為交流與開發提供了便利。 2.UML分類 UML圖形主要有用例圖、類圖、順序圖、狀態圖、活動圖。不同的視圖從不同的角度反映系統的特征。 二 用例圖 Use Case Diag ...
  • 學過前端開發的地球人應該都瞭解,JavaScript分為三個部分:ECMAScript(JS語言本身基礎語法),DOM(文檔對象模型,應用程式編程介面),BOM(瀏覽器對象模型)。 BOM,實際上與瀏覽器有關係。因此瀏覽器廠商可以按照各自的想法隨意去擴展(基於window對象的擴展)。不過,擴展歸擴 ...
  • <meta charset="utf-8">告訴瀏覽器要用utf-8來解釋,同時,保存文檔時,編碼格式也要為utf-8格式。 ...
  • rem由來:font size of the root element,那麼rem是個單位,單位大小由它第一代老祖宗的font-size的大小決定。現在前端碼農們為了能在各個屏幕上看到一個健康的網頁在默默的犧牲著自己的健康,因為不僅要知道rem是個單位,更重要的是要知道怎麼能在不同解析度下呈現的頁面 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...