Lasy_load_img_Library

2.0

This script should not be not be installed directly. It is a library for other scripts to include with the meta directive // @require https://update.greatest.deepsurf.us/scripts/488188/1475752/Lasy_load_img_Library.js

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey, Greasemonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

You will need to install an extension such as Tampermonkey to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्क्रिप्ट व्यवस्थापक एक्स्टेंशन इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्क्रिप्ट व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्टाईल व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

// ==UserScript==
// @name         Lasy_load_img_Library 3.0
// @namespace    http://tampermonkey.net/
// @version      2024.11.1
// @description  全新的写法
// @author       You
// @grant        none
// @include      *
// ==/UserScript==

function LazyLoad(){
	// let downloader = new window.GAIL.Downloader();
	let loadType = "ImgLoad";
	this.Set_laodType = (n)=>{loadType = n;};
	
	this.Start = async (srcs,imgs)=>{
		for(var i=0;i<imgs.length;i++){
			const img = imgs.eq(i);
			const src = srcs[i];
			if(loadType == "ImgLoad"){
				StartLoadOne(img);
				await ByLoadEvent(src);
				LoadedOne(src,img);
			}
		}
		AllOver();
	}
	function ByLoadEvent(src) {
	    return new Promise((resolve, reject) => {
	        const img = new Image(); // 使用 Image 构造函数
	        img.onload = () => resolve(); // 使用箭头函数
	        img.onerror = () => reject(); // 使用箭头函数
	        img.src = src;
	    });
	}
	let StartLoadOne = (img)=>{
		const p = $("<p>loading</p>");
		img.after(p);
	};
	this.OnStartLoadOne = (foo)=>{StartLoadOne = foo;}
	let LoadedOne = (src,img)=>{
		img.next("p").remove();
		img[0].src = src;
		console.log(src);
	};
	this.OnLoadedOne = (foo)=>{LoadedOne = foo;}
	let AllOver = ()=>{};
	this.OnAllOver = (foo)=>{AllOver = foo;};
}
window.LazyLoad = LazyLoad;