js, um einen einfachen Drag-Effekt zu erzielen

js, um einen einfachen Drag-Effekt zu erzielen

In diesem Artikel wird der spezifische Code von js zur Erzielung eines einfachen Drag-Effekts als Referenz bereitgestellt. Der spezifische Inhalt ist wie folgt

1. Grundlegende Effekte des Ziehens

Ideen:

Wenn die Maus auf die Box gedrückt wird, ist sie bereit zur Bewegung (das Ereignis wird dem Objekt hinzugefügt).

Wenn die Maus bewegt wird, folgt die Box der Maus (das Ereignis wird der Seite hinzugefügt)

Wenn die Maus angehoben wird, stoppt die Bewegung der Box (das Ereignis wird der Seite hinzugefügt).

var o = document.querySelector('div');
 
        //Maus runter o.onmousedown = function (e) {
            //Mausposition relativ zur Box var offsetX = e.clientX - o.offsetLeft;
            var offsetY = e.clientY - o.offsetTop;
            //Mausbewegung document.onmousemove = function (e) {
                o.style.left = e.clientX - offsetX + "px";
                o.style.top = e.clientY - offsetY + "px";
            }
            //Maus hoch document.onmouseup = function () {
                Dokument.onmousemove = null;
                Dokument.onmouseup = null;
            }
        }

2. Drag & Drop-Probleme

Wenn in der Box Text angezeigt wird oder die Box selbst ein Bild ist, können wir aufgrund des Standardverhaltens des Browsers (Text und Bilder können gezogen werden) „return false“ festlegen, um das Standardverhalten zu verhindern. Dieses Abfangen des Standardverhaltens ist jedoch in niedrigeren IE-Versionen nicht anwendbar. Sie können das IE-Problem mithilfe der globalen Erfassung lösen.

Globale Erfassung

Die globale Erfassung ist nur auf niedrigere IE-Versionen anwendbar.

<button>btn1</button>
    <button>btn2</button>
    <Skript>
        var bts = document.querySelectorAll('Schaltfläche')
 
        bts[0].onclick = Funktion () {
            konsole.log(1);
        }
        bts[1].onclick = Funktion () {
            konsole.log(2);
        }
 
        // bts[0].setCapture() //Globale Erfassung hinzufügen // bts[0].releaseCapture() ; //Globale Erfassung freigeben</script>

Sobald eine globale Erfassung für einen angegebenen Knoten hinzugefügt wurde, lösen andere Elemente auf der Seite nicht mehr denselben Ereignistyp aus.

3. Vollversion von Drag & Drop

var o = document.querySelector('div');
 
        //Maus runter o.onmousedown = function (e) {
            if (o.setCapture) { //IE niedrigere Version o.setCapture()
            }
            e = e || Fenster.Ereignis
            //Mausposition relativ zur Box var offsetX = e.clientX - o.offsetLeft;
            var offsetY = e.clientY - o.offsetTop;
            //Mausbewegung document.onmousemove = function (e) {
                e = e || Fenster.Ereignis
                o.style.left = e.clientX - offsetX + "px";
                o.style.top = e.clientY - offsetY + "px";
            }
            //Maus hoch document.onmouseup = function () {
                Dokument.onmousemove = null;
                Dokument.onmouseup = null;
                wenn (o.releaseCapture) {
                    o.releaseCapture(); //Globale Erfassung freigeben}
            }
            return false; //Standardverhalten von Standardbrowsern}

Das Obige ist der vollständige Inhalt dieses Artikels. Ich hoffe, er wird für jedermanns Studium hilfreich sein. Ich hoffe auch, dass jeder 123WORDPRESS.COM unterstützen wird.

Das könnte Sie auch interessieren:
  • JQuery-Dialog (JS-Modalfenster, verschiebbares DIV)
  • Analyse der Verwendung der Drag & Drop-Sortierung von Sortable.js
  • js, um einen Drag-Effekt zu erzielen
  • JavaScript implementiert die Touchscreen-Drag-Funktion auf mobilen Endgeräten
  • Einfacher Drag-Effekt mit js implementiert
  • JS realisiert einen schönen Fenster-Drag-Effekt (Größe kann geändert, maximiert, minimiert, geschlossen werden)
  • Beispiel einer Drag-and-Drop-Upload-Funktion für Dateien, die von JS implementiert wurde
  • Verwenden von Javascript zum Implementieren von Maus-Drag-Ereignissen
  • Implementierungscode für den Drag-Effekt der JS-Komponente Bootstrap Table Table
  • JavaScript implementiert den horizontalen Fortschrittsbalken-Drag-Effekt

<<:  js, um einen Boden-Scrolling-Effekt zu erzielen

>>:  Beispielcode zur Konvertierung von http in https mit nginx

Artikel empfehlen

Tutorial zu HTML-Tabellen-Tags (12): Rahmenstil-Attribut FRAME

Verwenden Sie die FRAME-Eigenschaft, um den Stilt...

Ausführliche Erläuterung der gespeicherten MySQL-Prozeduren (in, out, inout)

1. Einleitung Es wird seit Version 5.0 unterstütz...

Detaillierte Erläuterung des Docker-Visualisierungsgrafiktools Portainer

Inhaltsverzeichnis 1. Einführung in Portainer 2. ...

Einführung in Jenkins und wie man Jenkins mit Docker bereitstellt

1. Verwandte Konzepte 1.1 Jenkins-Konzepte: Jenki...

Neue Einstellungen für Text und Schriftarten in CSS3

Textschatten Textschatten: horizontaler Versatz, ...

MySQL REVOKE zum Löschen von Benutzerberechtigungen

In MySQL können Sie mit der REVOKE-Anweisung best...

MYSQL METADATA LOCK (MDL LOCK) MDL-Sperrproblemanalyse

1. Einleitung MDL-Sperren in MySQL haben schon im...

Allgemeiner HTML-Seitenstil (empfohlen)

Wie unten dargestellt: XML/HTML-CodeInhalt in die...

Webdesign: Wenn der Titel nicht vollständig angezeigt werden kann

<br />Ich habe mir heute die neu gestaltete ...

So verhindern Sie doppelte Übermittlungen in einem JQuery-Projekt

In neuen Projekten kann Axios doppelte Übermittlu...

Index in MySQL

Vorwort Kommen wir gleich zur Sache. Die folgende...

So migrieren Sie MySQL-Daten richtig nach Oracle

In der MySQL-Datenbank gibt es eine Tabelle Stude...