Anpassbare HTML-Elemente mit reinem JavaScript erstellen
Es gibt zahlreiche Bibliotheken, um die Größenänderung von Elementen zu ermöglichen, aber für diejenigen, die eine reine JavaScript-Lösung suchen, gibt es Folgendes Schritte können verwendet werden:
- Ereignis-Listener: Hängen Sie ein Klickereignis an Listener auf das gewünschte HTML-Element. Dadurch wird der Größenänderungsprozess eingeleitet.
- Klassenzusatz: Fügen Sie dem Element eine CSS-Klasse hinzu, z. B. „resizable“, um visuell anzuzeigen, dass es in den Größenänderungsmodus gewechselt ist.
-
Resizer-Element-Erstellung: Erstellen Sie ein neues HTML-Element, z. B. ein , und weisen Sie ihm die Klasse zu „Resizer.“ Dieses Element dient als Ziehgriff.
- Ereignis-Listener für Resizer: Fügen Sie dem Resizer einen Mousedown-Ereignis-Listener hinzu, der den Start des Ziehvorgangs auslöst.
- Drag-Initiierung: Speichern Sie die anfängliche Mausposition und die Elementabmessungen und ändern Sie die Größe Element.
- Drag-Funktion: Fügen Sie dem Dokument einen Mousemove-Ereignis-Listener hinzu, um die Abmessungen des Elements zu aktualisieren, wenn die Maus bewegt wird.
- Drag-Beendigung: Entfernen Sie beim Mouseup die Ereignis-Listener „Mousemove“ und „Mouseup“, um die Größenänderung abzuschließen Prozess.
Hier ist ein Beispielcode-Snippet, das diesen Ansatz implementiert:
var p = document.querySelector('p'); // element to make resizable p.addEventListener('click', function init() { p.removeEventListener('click', init, false); p.className = p.className + ' resizable'; var resizer = document.createElement('div'); resizer.className = 'resizer'; p.appendChild(resizer); resizer.addEventListener('mousedown', initDrag, false); }, false); var startX, startY, startWidth, startHeight; function initDrag(e) { startX = e.clientX; startY = e.clientY; startWidth = parseInt(document.defaultView.getComputedStyle(p).width, 10); startHeight = parseInt(document.defaultView.getComputedStyle(p).height, 10); document.documentElement.addEventListener('mousemove', doDrag, false); document.documentElement.addEventListener('mouseup', stopDrag, false); } function doDrag(e) { p.style.width = (startWidth + e.clientX - startX) + 'px'; p.style.height = (startHeight + e.clientY - startY) + 'px'; } function stopDrag(e) { document.documentElement.removeEventListener('mousemove', doDrag, false); document.documentElement.removeEventListener('mouseup', stopDrag, false); }
Beachten Sie, dass dieser Ansatz möglicherweise nicht mit allen Browsern und Internet Explorer niedrigeren Versionen kompatibel ist Es ist insbesondere bekannt, dass es bei Nr. 9 Probleme gibt.
Das obige ist der detaillierte Inhalt vonWie erstelle ich skalierbare HTML-Elemente mit reinem JavaScript?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die CSS-Box-Shadow- und Umrisseigenschaften haben Thema gewonnen. JSON-Unterstützung in WordPress 6.1. Sei ein paar Beispiele für die Funktionsweise in realen Themen und welche Optionen wir diese Stile auf WordPress -Blöcke und Elemente anwenden müssen.

Wenn Sie kürzlich mit GraphQL gearbeitet oder seine Vor- und Nachteile überprüft haben, haben Sie zweifellos Dinge wie "GraphQL nicht unterstützen Caching" oder gehört

Die Sufelte Transition -API bietet eine Möglichkeit, Komponenten zu beleben, wenn sie das Dokument eingeben oder verlassen, einschließlich benutzerdefinierter Svelte -Übergänge.

In diesem Artikel werden wir in die Welt der Scrollbars eintauchen. Ich weiß, es klingt nicht zu glamourös, aber vertrau mir, eine gut gestaltete Seite geht Hand in Hand

Wie viel Zeit damit, die Inhaltspräsentation für Ihre Websites zu entwerfen? Wenn Sie einen neuen Blog -Beitrag schreiben oder eine neue Seite erstellen, denken Sie darüber nach

Mit dem jüngsten Aufstieg von Bitcoins Preis über 20.000 USD und kürzlich von 30.000, dachte ich, es lohnt

NPM-Befehle führen verschiedene Aufgaben für Sie aus, entweder als einmalige oder als kontinuierlich ausgeführter Vorgang für Dinge wie das Starten eines Servers oder das Kompilieren von Code.

Ich habe mich neulich mit Eric Meyer unterhalten und erinnerte mich an eine Eric Meyer -Geschichte aus meinen prägenden Jahren. Ich habe einen Blog -Beitrag über CSS -Spezifität geschrieben, und


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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

Dreamweaver CS6
Visuelle Webentwicklungstools

Dreamweaver Mac
Visuelle Webentwicklungstools

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

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.