Heim Web-Frontend H5-Tutorial JS-Code zur Implementierung des Wasserfall-Flow-Plug-Ins

JS-Code zur Implementierung des Wasserfall-Flow-Plug-Ins

Feb 07, 2018 am 09:25 AM
javascript 插件

Die Bilder im Wasserfall-Flow-Layout haben ein Kernmerkmal: gleiche Breite und variable Höhe. Das Wasserfall-Flow-Layout wird in gewissem Umfang auf inländischen Websites wie Pinterest, Huaban.com usw. verwendet. In diesem Artikel wird hauptsächlich ein natives JS-Wasserfall-Flow-Plugin und codebezogene Erklärungen analysiert. Ich hoffe, es kann Ihnen helfen.

Grundlegende Funktionsimplementierung

Zuerst definieren wir einen Container mit 20 Bildern,


<body>
 <style>
  #waterfall {
   position: relative;
  }
  .waterfall-box {
   float: left;
   width: 200px;
  }
 </style>
</body>
<p id="waterfall">
  <img src="images/1.png" class="waterfall-box">
  <img src="images/2.png" class="waterfall-box">
  <img src="images/3.png" class="waterfall-box">
  <img src="images/4.png" class="waterfall-box">
  <img src="images/5.png" class="waterfall-box">
  <img src="images/6.png" class="waterfall-box">
  ...
 </p>
由于未知的 css 知识点,丝袜最长的妹子把下面的空间都占用掉了。。。
接着正文,假如如上图,每排有 5 列,那第 6 张图片应该出现前 5 张图片哪张的下面呢?当然是绝对定位到前 5 张图片高度最小的图片下方。
那第 7 张图片呢?这时候把第 6 张图片和在它上面的图片当作是一个整体后,思路和上述是一致的。代码实现如下:
Waterfall.prototype.init = function () {
 ...
 const perNum = this.getPerNum() // 获取每排图片数
 const perList = []       // 存储第一列的各图片的高度
 for (let i = 0; i < perNum; i++) {
  perList.push(imgList[i].offsetHeight)
 }
 let pointer = this.getMinPointer(perList) // 求出当前最小高度的数组下标
 for (let i = perNum; i < imgList.length; i++) {
  imgList[i].style.position = &#39;absolute&#39; // 核心语句
  imgList[i].style.left = `${imgList[pointer].offsetLeft}px`
  imgList[i].style.top = `${perList[pointer]}px`

  perList[pointer] = perList[pointer] + imgList[i].offsetHeight // 数组最小的值加上相应图片的高度
  pointer = this.getMinPointer(perList)
 }
}
Nach dem Login kopieren

Sorgfältige Freunde Möglicherweise wurde festgestellt, dass das Attribut offsetHeight verwendet wird, um die Höhe des Bildes im Code zu ermitteln. Die Summe der Höhen dieses Attributs ist gleich 图片高度 + 内边距 + 边框. Aus diesem Grund verwenden wir zum Festlegen den Abstand Abstand zwischen den Bildern. Zusätzlich zum Attribut offsetHeight müssen Sie auch die Unterschiede zwischen offsetHeight, clientHeight, offsetTop, scrollTop und anderen Attributen verstehen, um dieses Projekt besser zu verstehen. Der CSS-Code ist einfach wie folgt:


.waterfall-box {
 float: left;
 width: 200px;
 padding-left: 10px;
 padding-bottom: 10px;
}
Nach dem Login kopieren

Implementierung der Scroll- und Größenänderungsereignisüberwachung

Nach der Initialisierungsfunktion init implementiert ist, besteht der erste Schritt darin, das Bildlaufereignis zu überwachen, sodass ein stetiger Strom von Bildern geladen wird, wenn der Bildlauf den unteren Rand des übergeordneten Knotens erreicht. Ein zu diesem Zeitpunkt zu berücksichtigender Punkt ist: An welcher Position wird die Ladefunktion beim Scrollen ausgelöst? Dies ist von Person zu Person unterschiedlich. Mein Ansatz besteht darin, die Ladefunktion auszulösen, wenn die Bedingung 父容器高度 + 滚动距离 > 最后一张图片的 offsetTop erfüllt ist, also orange Linie + violette Linie > 🎜>


Da der übergeordnete Knoten den Knoten anpassen kann, bietet er eine Kapselung der Scroll-Überwachungsfunktion. Der Code lautet wie folgt:

window.onscroll = function() {
 // ...
 if (scrollPX + bsHeight > imgList[imgList.length - 1].offsetTop) {// 浏览器高度 + 滚动距离 > 最后一张图片的 offsetTop
  const fragment = document.createDocumentFragment()
  for(let i = 0; i < 20; i++) {
   const img = document.createElement(&#39;img&#39;)
   img.setAttribute(&#39;src&#39;, `images/${i+1}.png`)
   img.setAttribute(&#39;class&#39;, &#39;waterfall-box&#39;)
   fragment.appendChild(img)
  }
  $waterfall.appendChild(fragment)
 }
}
Nach dem Login kopieren


Größenänderungsereignisüberwachung und Scrollen Die Ereignisüberwachung ist ähnlich. Wenn die Größenänderungsfunktion ausgelöst wird, rufen Sie einfach die Init-Funktion auf, um sie zurückzusetzen.

proto.bind = function () {
  const bindScrollElem = document.getElementById(this.opts.scrollElem)
  util.addEventListener(bindScrollElem || window, &#39;scroll&#39;, scroll.bind(this))
 }
 const util = {
  addEventListener: function (elem, evName, func) {
   elem.addEventListener(evName, func, false)
  },
 }
Nach dem Login kopieren
Verwenden Sie das Publish-Subscribe-Modell und die Vererbung, um die Listening-Bindung zu implementieren

Da das Ziel darin besteht, Plug-Ins zu entwickeln, können wir uns nicht nur mit der Realisierung von Funktionen zufrieden geben, sondern auch den entsprechenden Betrieb belassen Raum, mit dem sich Entwickler befassen können. Erinnern wir uns an das Dropdown-Laden von Bildern in Wasserfallflüssen in Geschäftsszenarien: Sie werden im Allgemeinen asynchron über Ajax abgerufen, sodass die geladenen Daten nicht in der Bibliothek fest codiert werden müssen. Es wird erwartet, dass die folgenden Aufrufe implementiert werden können (hier). Wir ziehen Lehren aus der Verwendung von Wasserfall). Das Publish/Subscribe-Modell wurde bereits im asynchronen asynchronen Datensatz von Node.js eingeführt. Die Kernidee besteht darin, die Funktion über die Abonnementfunktion zum Cache hinzuzufügen und dann den asynchronen Aufruf über die Veröffentlichungsfunktion zu implementieren. Die Codeimplementierung ist unten angegeben:


Um Waterfall die Verwendung des Veröffentlichungs-/Abonnementmodus zu ermöglichen, lassen Sie Waterfall einfach die eventEmitter-Funktion erben. Der Code wird wie folgt implementiert:

const waterfall = new Waterfall({options})
waterfall.on("load", function () {
 // 此处进行 ajax 同步/异步添加图片
})
Nach dem Login kopieren


Der Die Vererbungsmethode absorbiert die Vererbung und basierend auf den Vorteilen der beiden Schreibmethoden der Prototypkettenvererbung und der Verwendung von

zum Isolieren von Unterklassen und übergeordneten Klassen können Sie einen weiteren Artikel für weitere Details zur Vererbung schreiben, daher werde ich damit aufhören Hier.
function eventEmitter() {
 this.sub = {}
}
eventEmitter.prototype.on = function (eventName, func) { // 订阅函数
 if (!this.sub[eventName]) {
  this.sub[eventName] = []
 }
 this.sub[eventName].push(func) // 添加事件监听器
}
eventEmitter.prototype.emit = function (eventName) { // 发布函数
 const argsList = Array.prototype.slice.call(arguments, 1)
 for (let i = 0, length = this.sub[eventName].length; i < length; i++) {
  this.sub[eventName][i].apply(this, argsList) // 调用事件监听器
 }
}
Nach dem Login kopieren

Kleine Optimierung


Um zu verhindern, dass das Scroll-Ereignis das mehrfache Laden von Bildern auslöst, können Sie die Funktion Anti-Shake und Throttling verwenden. Basierend auf dem Publish-Subscribe-Modell wird ein isLoading-Parameter definiert, der angibt, ob er geladen wird, und ob er geladen werden soll, wird anhand seines booleschen Werts bestimmt. Der Code lautet wie folgt:
function Waterfall(options = {}) {
 eventEmitter.call(this)
 this.init(options) // 这个 this 是 new 的时候,绑上去的
}
Waterfall.prototype = Object.create(eventEmitter.prototype)
Waterfall.prototype.constructor = Waterfall
Nach dem Login kopieren

Object.create

Zu diesem Zeitpunkt müssen Sie zum Anrufort hinzufügen, um zu informieren, dass das aktuelle Bild geladen wurde. Der Code lautet wie folgt:


Verwandte Empfehlungen:
let isLoading = false
const scroll = function () {
 if (isLoading) return false // 避免一次触发事件多次
 if (scrollPX + bsHeight > imgList[imgList.length - 1].offsetTop) { // 浏览器高度 + 滚动距离 > 最后一张图片的 offsetTop
  isLoading = true
  this.emit(&#39;load&#39;)
 }
}
proto.done = function () {
 this.on(&#39;done&#39;, function () {
  isLoading = false
  ...
 })
 this.emit(&#39;done&#39;)
}
Nach dem Login kopieren

waterfall.done

Detaillierte Erläuterung der Verwendung des reinen nativen JS-Wasserfall-Flow-Plug-Ins Macy.js


const waterfall = new Waterfall({})
waterfall.on("load", function () {
 // 异步/同步加载图片
 waterfall.done()
})
Nach dem Login kopieren
Einführung in die Verwendung des JQuery-Wasserfall-Flow-Plug-ins_jquery


JQuery-Wasserfall-Flow-Plug-in Wookmark-Verwendungsbeispiel_jquery

Das obige ist der detaillierte Inhalt vonJS-Code zur Implementierung des Wasserfall-Flow-Plug-Ins. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PyCharm-Einsteigerhandbuch: Umfassendes Verständnis der Plug-In-Installation! PyCharm-Einsteigerhandbuch: Umfassendes Verständnis der Plug-In-Installation! Feb 25, 2024 pm 11:57 PM

PyCharm ist eine leistungsstarke und beliebte integrierte Entwicklungsumgebung (IDE) für Python, die eine Fülle von Funktionen und Tools bereitstellt, damit Entwickler Code effizienter schreiben können. Der Plug-In-Mechanismus von PyCharm ist ein leistungsstarkes Tool zur Erweiterung seiner Funktionen. Durch die Installation verschiedener Plug-Ins können PyCharm um verschiedene Funktionen und benutzerdefinierte Funktionen erweitert werden. Daher ist es für PyCharm-Neulinge von entscheidender Bedeutung, die Installation von Plug-Ins zu verstehen und zu beherrschen. In diesem Artikel erhalten Sie eine detaillierte Einführung in die vollständige Installation des PyCharm-Plug-Ins.

Fehler beim Laden des Plugins in Illustrator [Behoben] Fehler beim Laden des Plugins in Illustrator [Behoben] Feb 19, 2024 pm 12:00 PM

Erscheint beim Starten von Adobe Illustrator eine Meldung über einen Fehler beim Laden des Plug-Ins? Bei einigen Illustrator-Benutzern ist dieser Fehler beim Öffnen der Anwendung aufgetreten. Der Meldung folgt eine Liste problematischer Plugins. Diese Fehlermeldung weist darauf hin, dass ein Problem mit dem installierten Plug-In vorliegt, es kann jedoch auch andere Gründe haben, beispielsweise eine beschädigte Visual C++-DLL-Datei oder eine beschädigte Einstellungsdatei. Wenn dieser Fehler auftritt, werden wir Sie in diesem Artikel bei der Behebung des Problems unterstützen. Lesen Sie daher weiter unten weiter. Fehler beim Laden des Plug-Ins in Illustrator Wenn Sie beim Versuch, Adobe Illustrator zu starten, die Fehlermeldung „Fehler beim Laden des Plug-Ins“ erhalten, können Sie Folgendes verwenden: Als Administrator

Was ist das Installationsverzeichnis der Chrome-Plug-in-Erweiterung? Was ist das Installationsverzeichnis der Chrome-Plug-in-Erweiterung? Mar 08, 2024 am 08:55 AM

Was ist das Installationsverzeichnis der Chrome-Plug-in-Erweiterung? Unter normalen Umständen lautet das Standardinstallationsverzeichnis von Chrome-Plug-In-Erweiterungen wie folgt: 1. Der Standard-Installationsverzeichnis-Speicherort von Chrome-Plug-Ins in Windows XP: C:\DocumentsandSettings\Benutzername\LocalSettings\ApplicationData\Google\Chrome\UserData\ Default\Extensions2. Chrome in Windows7 Der Standardinstallationsverzeichnisspeicherort des Plug-Ins: C:\Benutzer\Benutzername\AppData\Local\Google\Chrome\User

Teilen Sie drei Lösungen mit, warum der Edge-Browser dieses Plug-in nicht unterstützt Teilen Sie drei Lösungen mit, warum der Edge-Browser dieses Plug-in nicht unterstützt Mar 13, 2024 pm 04:34 PM

Wenn Benutzer den Edge-Browser verwenden, fügen sie möglicherweise einige Plug-Ins hinzu, um weitere Anforderungen zu erfüllen. Beim Hinzufügen eines Plug-Ins wird jedoch angezeigt, dass dieses Plug-In nicht unterstützt wird. Heute stellt Ihnen der Herausgeber drei Lösungen vor. Methode 1: Versuchen Sie es mit einem anderen Browser. Methode 2: Der Flash Player im Browser ist möglicherweise veraltet oder fehlt, sodass das Plug-in nicht unterstützt wird. Sie können die neueste Version von der offiziellen Website herunterladen. Methode 3: Drücken Sie gleichzeitig die Tasten „Strg+Umschalt+Entf“. Klicken Sie auf „Daten löschen“ und öffnen Sie den Browser erneut.

WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen Dec 17, 2023 pm 05:30 PM

WebSocket und JavaScript: Schlüsseltechnologien zur Realisierung von Echtzeit-Überwachungssystemen Einführung: Mit der rasanten Entwicklung der Internet-Technologie wurden Echtzeit-Überwachungssysteme in verschiedenen Bereichen weit verbreitet eingesetzt. Eine der Schlüsseltechnologien zur Erzielung einer Echtzeitüberwachung ist die Kombination von WebSocket und JavaScript. In diesem Artikel wird die Anwendung von WebSocket und JavaScript in Echtzeitüberwachungssystemen vorgestellt, Codebeispiele gegeben und deren Implementierungsprinzipien ausführlich erläutert. 1. WebSocket-Technologie

Unterstützt PyCharm Community Edition genügend Plugins? Unterstützt PyCharm Community Edition genügend Plugins? Feb 20, 2024 pm 04:42 PM

Unterstützt PyCharm Community Edition genügend Plugins? Benötigen Sie spezifische Codebeispiele Da die Python-Sprache im Bereich der Softwareentwicklung immer häufiger verwendet wird, wird PyCharm als professionelle integrierte Python-Entwicklungsumgebung (IDE) von Entwicklern bevorzugt. PyCharm ist in zwei Versionen unterteilt: die professionelle Version und die Community-Version. Die Community-Version wird kostenlos bereitgestellt, die Plug-in-Unterstützung ist jedoch im Vergleich zur professionellen Version eingeschränkt. Die Frage ist also: Unterstützt die PyCharm Community Edition genügend Plug-Ins? In diesem Artikel werden spezifische Codebeispiele verwendet

Wir geben Tipps zur Installation des PyCharm-Plug-ins, damit Sie mit halbem Aufwand das doppelte Ergebnis erzielen! Wir geben Tipps zur Installation des PyCharm-Plug-ins, damit Sie mit halbem Aufwand das doppelte Ergebnis erzielen! Feb 21, 2024 pm 06:36 PM

PyCharm ist eine leistungsstarke integrierte Python-Entwicklungsumgebung. Durch die Installation von Plug-Ins können Sie die Entwicklungseffizienz weiter verbessern und die Arbeit der Entwickler erleichtern. In diesem Artikel werden einige Tipps zur Installation des PyCharm-Plug-Ins gegeben, damit Sie mit halbem Aufwand das Doppelte des Ergebnisses erzielen können. Außerdem werden konkrete Codebeispiele zur Veranschaulichung der Verwendung des Plug-Ins bereitgestellt. Schritt 1: Öffnen Sie PyCharm, klicken Sie in der Menüleiste auf „Datei“ und wählen Sie dann „Einstellungen“. Schritt 2: Klicken Sie im Fenster „Einstellungen“ auf „

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Dec 17, 2023 pm 05:13 PM

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Einführung: Heutzutage ist die Genauigkeit von Wettervorhersagen für das tägliche Leben und die Entscheidungsfindung von großer Bedeutung. Mit der Weiterentwicklung der Technologie können wir genauere und zuverlässigere Wettervorhersagen liefern, indem wir Wetterdaten in Echtzeit erhalten. In diesem Artikel erfahren Sie, wie Sie mit JavaScript und WebSocket-Technologie ein effizientes Echtzeit-Wettervorhersagesystem aufbauen. In diesem Artikel wird der Implementierungsprozess anhand spezifischer Codebeispiele demonstriert. Wir

See all articles