


js-Lösung, um zu verhindern, dass das DIV-Layout beim Scrollen blinkt_Javascript-Kenntnisse
Das Beispiel in diesem Artikel beschreibt die js-Methode, um zu verhindern, dass das DIV-Layout beim Scrollen flackert, und ich möchte es Ihnen als Referenz zur Verfügung stellen. Die spezifische Methode ist wie folgt:
Zu den Dingen, mit denen ich in letzter Zeit in Bezug auf die Seitenleistung konfrontiert wurde, gehören viele subtile und originelle Inhalte, wie zum Beispiel das Browser-Rendering. Es gibt viele Informationen, daher habe ich einige für Auszüge und Memos ausgewählt.
Wenn JavaScript das DOM mehrmals schreibt und liest, kommt es zu „Layout-Thrashing“, was zu einem Dokument-Reflow führt (Reflow – der Prozess der Erstellung eines Render-Baums
// Lesen
var h1 = element1.clientHeight;
// Schreiben (Layout ungültig)
element1.style.height = (h1 * 2) 'px';
// Lesen (Trigger-Layout)
var h2 = element2.clientHeight;
// Schreiben (Layout ungültig)
element2.style.height = (h2 * 2) 'px';
// Lesen (Trigger-Layout)
var h3 = element3.clientHeight;
// Schreiben (Layout ungültig)
element3.style.height = (h3 * 2) 'px';
Wenn das DOM geschrieben wird, ist das Layout ungültig und muss zu einem bestimmten Zeitpunkt neu angeordnet werden. Aber der Browser ist sehr faul, er möchte bis zum Ende des aktuellen Vorgangs (oder Frames) warten, bevor er neu fließt.
Wenn wir jedoch den geometrischen Wert vor dem Ende des aktuellen Vorgangs (oder Frames) aus dem DOM lesen, zwingen wir den Browser, das Layout im Voraus neu anzuordnen. Dies ist das sogenannte „erzwungene synchrone Layout“. Es tötet die Leistung.
Bei einem modernen Desktop-Browser sind die Nebenwirkungen des Layout-Thrashings vielleicht nicht offensichtlich, aber auf Low-End-Mobilgeräten ist das Problem ernst.
Schnelle Lösung
In einer idealen Welt können wir DOM stapelweise lesen und schreiben, indem wir einfach die Reihenfolge der Codeausführung ändern. Das bedeutet, dass das Dokument nur einmal umgebrochen werden muss.
var h1 = element1.clientHeight;
var h2 = element2.clientHeight;
var h3 = element3.clientHeight;
// Schreiben (Layout ungültig)
element1.style.height = (h1 * 2) 'px';
element2.style.height = (h2 * 2) 'px';
element3.style.height = (h3 * 2) 'px';
// Dokument fließt am Ende des Frames neu
Was ist mit der realen Welt?
In Wirklichkeit ist es nicht so einfach. In großen Programmen ist der Code überall verteilt und dieses gefährliche DOM existiert überall. Wir können (und sollten es natürlich auch nicht) unseren schönen, entkoppelten Code nicht einfach zusammenmischen, nur um die Ausführungsreihenfolge zu steuern. Wie führen wir also Batch-Lese- und Schreibvorgänge durch, um die Leistung zu optimieren?
Meet requestAnimationFrame
window.requestAnimationFrame plant eine Funktion, die im nächsten Frame ausgeführt werden soll, ähnlich wie setTimout(fn, 0). Dies ist sehr nützlich, da wir damit die gemeinsame Ausführung aller DOM-Schreibvorgänge im nächsten Frame und die synchrone Ausführung der DOM-Lesevorgänge in der aktuellen Reihenfolge planen können.
var h1 = element1.clientHeight;
// schreibe
requestAnimationFrame(function() {
element1.style.height = (h1 * 2) 'px';
});
// Lesen
var h2 = element2.clientHeight;
// schreibe
requestAnimationFrame(function() {
element2.style.height = (h2 * 2) 'px';
});
……
Ich hoffe, dass dieser Artikel für alle bei der Webprogrammierung auf Basis von JavaScript hilfreich sein wird.

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die MySQL -Verbindung kann auf die folgenden Gründe liegen: MySQL -Dienst wird nicht gestartet, die Firewall fängt die Verbindung ab, die Portnummer ist falsch, der Benutzername oder das Kennwort ist falsch, die Höradresse in my.cnf ist nicht ordnungsgemäß konfiguriert usw. Die Schritte zur Fehlerbehebung umfassen: 1. Überprüfen Sie, ob der MySQL -Dienst ausgeführt wird. 2. Passen Sie die Firewall -Einstellungen an, damit MySQL Port 3306 anhören kann. 3. Bestätigen Sie, dass die Portnummer mit der tatsächlichen Portnummer übereinstimmt. 4. Überprüfen Sie, ob der Benutzername und das Passwort korrekt sind. 5. Stellen Sie sicher, dass die Einstellungen für die Bindungsadresse in my.cnf korrekt sind.

Die Lösung für den MySQL -Installationsfehler ist: 1. Überprüfen Sie die Systemumgebung sorgfältig, um sicherzustellen, dass die Anforderungen der MySQL -Abhängigkeitsbibliothek erfüllt werden. Unterschiedliche Betriebssysteme und Versionsanforderungen sind unterschiedlich. 2. Lesen Sie die Fehlermeldung sorgfältig durch und ergreifen Sie entsprechende Maßnahmen gemäß den Eingabeaufforderungen (z. B. fehlende Bibliotheksdateien oder unzureichende Berechtigungen), z. B. die Installation von Abhängigkeiten oder die Verwendung von SUDO -Befehlen; 3. Versuchen Sie bei Bedarf, den Quellcode zu installieren und das Kompilierungsprotokoll sorgfältig zu überprüfen. Dies erfordert jedoch eine bestimmte Menge an Linux -Kenntnissen und -erfahrung. Der Schlüssel zur letztendlichen Lösung des Problems besteht darin, die Systemumgebung und Fehlerinformationen sorgfältig zu überprüfen und auf die offiziellen Dokumente zu verweisen.

Die Hauptgründe, warum Sie sich bei MySQL nicht als Root anmelden können, sind Berechtigungsprobleme, Konfigurationsdateifehler, Kennwort inkonsistent, Socket -Dateiprobleme oder Firewall -Interception. Die Lösung umfasst: Überprüfen Sie, ob der Parameter Bind-Address in der Konfigurationsdatei korrekt konfiguriert ist. Überprüfen Sie, ob die Root -Benutzerberechtigungen geändert oder gelöscht und zurückgesetzt wurden. Stellen Sie sicher, dass das Passwort korrekt ist, einschließlich Fall- und Sonderzeichen. Überprüfen Sie die Einstellungen und Pfade der Socket -Dateiberechtigte. Überprüfen Sie, ob die Firewall Verbindungen zum MySQL -Server blockiert.

Es gibt viele Gründe, warum MySQL Startup fehlschlägt und durch Überprüfung des Fehlerprotokolls diagnostiziert werden kann. Zu den allgemeinen Ursachen gehören Portkonflikte (prüfen Portbelegung und Änderung der Konfiguration), Berechtigungsprobleme (Überprüfen Sie den Dienst Ausführen von Benutzerberechtigungen), Konfigurationsdateifehler (Überprüfung der Parametereinstellungen), Datenverzeichniskorruption (Wiederherstellung von Daten oder Wiederaufbautabellenraum), InnoDB-Tabellenraumprobleme (prüfen IBDATA1-Dateien), Plug-in-Ladeversagen (Überprüfen Sie Fehlerprotokolle). Wenn Sie Probleme lösen, sollten Sie sie anhand des Fehlerprotokolls analysieren, die Hauptursache des Problems finden und die Gewohnheit entwickeln, Daten regelmäßig zu unterstützen, um Probleme zu verhindern und zu lösen.

Die folgenden Schritte können verwendet werden, um das Problem zu beheben, das Navicat keine Verbindung zur Datenbank herstellen kann: Überprüfen Sie die Serververbindung, stellen Sie sicher, dass der Server ausgeführt wird, adressiert und port korrekt und die Firewall erlaubt Verbindungen. Überprüfen Sie die Anmeldeinformationen und bestätigen Sie, dass der Benutzername, das Kennwort und die Berechtigungen korrekt sind. Überprüfen Sie Netzwerkverbindungen und Fehlerbehebung mit Netzwerkproblemen wie Router oder Firewall -Fehlern. Deaktivieren Sie SSL -Verbindungen, die von einigen Servern möglicherweise nicht unterstützt werden. Überprüfen Sie die Datenbankversion, um sicherzustellen, dass die Navicat -Version mit der Zieldatenbank kompatibel ist. Passen Sie das Verbindungs -Zeitüberschreitende an und erhöhen Sie für Remote- oder langsamere Verbindungen das Zeitüberschreitungszeitübergang. Andere Problemumgehungen, wenn die oben genannten Schritte nicht funktionieren, können Sie versuchen, die Software neu zu starten, einen anderen Verbindungsfahrer zu verwenden oder den Datenbankadministrator oder den offiziellen Navicat -Support zu konsultieren.

MySQL unterstützt keine Array -Typen im Wesentlichen, kann das Land durch folgende Methoden retten: JSON -Array (eingeschränkte Leistungseffizienz); mehrere Felder (schlechte Skalierbarkeit); Assoziative Tabellen (am flexibelsten und entsprechen der Designidee relationaler Datenbanken).

Die Beschädigung der MySQL -Konfigurationsdatei kann über die folgenden Lösungen repariert werden: 1. Einfaches Fix: Wenn nur eine kleine Anzahl von Fehlern (z. B. fehlende Semikolons) vorliegt, verwenden Sie einen Texteditor, um ihn zu korrigieren und sich vor dem Ändern sicher zu sichern. 2. Vollständiger Rekonstruktion: Wenn die Korruption ernst ist oder die Konfigurationsdatei nicht gefunden werden kann, siehe das offizielle Dokument oder kopiert die Standardkonfigurationsdatei derselben Version und ändere sie dann nach den Anforderungen. 3. Verwenden Sie das Installationsprogramm, um eine Reparaturfunktion bereitzustellen: Versuchen Sie, die Konfigurationsdatei automatisch mithilfe der vom Installationsprogramm bereitgestellten Reparaturfunktion zu reparieren. Nachdem Sie die entsprechende Lösung für die Reparatur ausgewählt haben, müssen Sie den MySQL -Service neu starten und überprüfen, ob er erfolgreich ist, und gute Sicherungsgewohnheiten zu entwickeln, um solche Probleme zu verhindern.

MySQL Download fordert einen Schreibfehler auf. Die Lösung lautet wie folgt: 1. Überprüfen Sie, ob der Scheibenraum nicht ausreicht, den Raum aufräumen oder eine größere Festplatte ersetzen; 2. Verwenden Sie die Festplattenerkennungswerkzeuge (z. B. CHKDSK oder FSCK), um Festplattenfehler zu überprüfen und zu beheben und die Festplatte gegebenenfalls zu ersetzen. 3. Überprüfen Sie die Berechtigungen des Zielverzeichnisses, um sicherzustellen, dass das Benutzerkonto Schreibberechtigungen enthält. 4. Ändern Sie das Download -Tool oder die Netzwerkumgebung und verwenden Sie den Download -Manager, um den unterbrochenen Download wiederherzustellen. 5. Schließen Sie vorübergehend die Anti-Virus-Software oder Firewall und können Sie nach Abschluss des Downloads erneut anerkannt. Durch die systematische Fehlerbehebung bei diesen Aspekten kann das Problem gelöst werden.
