Inhaltsverzeichnis
Standard-Drag
Element-Ziehen
Ereignis ziehen
Element ziehen
Zielelement
Datenaustausch
Drag-and-Drop-Einstellungen
dropEffect
effectAllowed
Heim Web-Frontend H5-Tutorial Eine detaillierte Einführung in APIs im Zusammenhang mit dem Drag-and-Drop von HTML5-Elementen (Bilder und Text)

Eine detaillierte Einführung in APIs im Zusammenhang mit dem Drag-and-Drop von HTML5-Elementen (Bilder und Text)

Mar 11, 2017 pm 03:58 PM

Tatsächlich fügt HTML5 nur einige nützliche APIs hinzu
Lassen Sie uns einfacher entwickeln
damit wir uns mehr auf die Geschäftslogik konzentrieren können
Die Verwendung dieser APIs ist auch sehr einfach
Aber ich meine Das Gedächtnis ist nicht sehr gut
Also habe ich es in Form eines Blogs aufgezeichnet (Handbuch lustig)
Heute werde ich über diese Drag-API schreiben

Standard-Drag

Apropos Drag Tatsächlich war die früheste Implementierung der Drag-and-Drop-Funktion IE (IE4).
H5 ist die Drag-and-Drop-Spezifikation, die auf IE-Instanzen basiert.
Im Browser gibt es ein Standard-Drag-and-Drop.
Zum Beispiel , Bilder Ziehen

Ziehen Sie den ausgewählten Text

Ziehen Sie den Link

Element-Ziehen

Der Browser ermöglicht uns standardmäßig das Ziehen von Bildern, Text und Links
Es ist auch möglich, andere Elemente zu ziehen
Nur ​​auf dem Element-Tag Attribut hinzufügen

<p draggable="true"></p>
Nach dem Login kopieren

Wenn dieses Element gezogen wird, zeigt der Browser eine durchsichtige Kopie an

Ereignis ziehen

Ereignis ziehen Es sollte in zwei Kategorien unterteilt werden
Eine davon ist das Ereignis ausgelöst durch das gezogene Element
Das andere ist das Ereignis, das durch das Drag-and-Drop-Zielelement ausgelöst wird

<p id="source" draggable="true"></p><p id="target"></p>  <!-- 样式略 -->
Nach dem Login kopieren
var source = document.getElementById(&#39;source&#39;);var target = document.getElementById(&#39;target&#39;);
Nach dem Login kopieren

Element ziehen

Beim Ziehen eines Elements wird das gezogene Element ausgelöst löst die folgenden Ereignisse aus:

  • Dragstart

  • Drag

  • dragend

Wenn die Maus auf das Element klickt und sich zu bewegen beginnt, wird das Dragstart-Ereignis ausgelöst (analog zu Mousedown).
Das Drag-Ereignis wird während des Ziehvorgangs kontinuierlich ausgelöst (analog zu Mousemove)
Wenn die Maus losgelassen wird, um das Ziehen abzubrechen, wird das Dragend-Ereignis (analog zu Mouseup) ausgelöst

source.ondragstart = function(){
  console.log(&#39;开始拖拽&#39;);
}source.ondrag = function(){
  console.log(&#39;拖拽中&#39;);
}source.ondragend = function(){
  console.log(&#39;拖拽结束&#39;);
}
Nach dem Login kopieren

Zielelement

Wenn das gezogene Element auf ein Zielelement gezogen wird, löst das Zielelement die folgenden Ereignisse aus

  • dragenter

  • Dragover

  • Dragleave

  • Drop

Ziehen Sie das Element auf das Ziel, und das Dragenter-Ereignis wird ausgelöst (analog zum Mouseover)
Wenn sich das gezogene Element auf dem Ziel befindet Element wird das Dragover-Ereignis weiterhin ausgelöst
Zielelement verlassen und Dragleave-Ereignis auslösen (analog zu Mouseout)
Wenn das Element per Drag & Drop in das Zielelement gezogen wird (Maus im Zielelement loslassen) , das Drop-Ereignis wird nicht ausgelöst

target.ondragenter = function(){
  console.log(&#39;拖动进入目标元素&#39;);
}target.ondragover = function(){
  console.log(&#39;目标元素中拖拽&#39;);
}target.ondragleave = function(){
  console.log(&#39;拖动离开目标元素&#39;);
}target.ondrop = function(){
  console.log(&#39;拖放&#39;);
}
Nach dem Login kopieren


Zu diesem Zeitpunkt werden wir feststellen, dass das Element per Drag & Drop verschoben wird in das Zielelement
das Drop-Ereignis wird nicht ausgelöst

Wir haben einen speziellen Cursor (Kreis + Backslash) gesehen
Es bedeutet ungültiges Drag & Drop
Das Drop-Ereignis wird also nicht ausgelöst
Das heißt, Elemente können standardmäßig nicht per Drag & Drop verschoben werden
Solange wir das Standardereignis im Dragover-Ereignis des Zielelements abbrechen, Das Problem kann gelöst werden

target.ondragover = function(e){
  console.log(&#39;目标元素中拖拽&#39;);
  e.preventDefault(); //增}
Nach dem Login kopieren

Datenaustausch

Nur ​​einfaches Ziehen und Ablegen ist bedeutungslos
Wir müssen Daten austauschen
Und der Gegenstand dieses Begriffs Datenaustausch ist der Attribut des EreignisobjektsdataTransfer
Die beiden Kernmethoden von dataTransfer sind setData( ) und getData()
setData() wird zum Festlegen von Daten und getData() zum Empfangen von Daten verwendet

event.dataTransfer.setData(&#39;text&#39;,&#39;some text&#39;);
var text = event.dataTransfer.getData(&#39;text&#39;);//保存在dataTransfer中的数据只能在drop事件处理函数中处理
Nach dem Login kopieren

Wenn wir den ausgewählten Text ziehen
, ruft der Browser standardmäßig dataTransfer auf und legt die entsprechenden Textdaten fest

setData() und getData() sind Zeichenfolgen von Datentypen
Neben dem Texttyp „Text“ umfassen die vom IE definierten Datentypen auch „URL“
H5 ist dafür geeignet. Es wurde erweitert, um verschiedene MIME-Typen anzugeben
Aber aus Gründen der Abwärtskompatibilität , es unterstützt auch „text“ und „URL“
Sie werden „text/plain“ bzw. „text/uri-list“ zugeordnet ”

Wenn die Daten als URL gespeichert werden, wird die Der Browser führt eine spezielle Verarbeitung durch und behandelt ihn als Weblink
(Wenn Sie also den Link in ein anderes Browserfenster ziehen, wird die Webseite geöffnet)


Bei Bedarf können wir die benötigten Daten manuell speichern übertragen werden

var source = document.getElementById(&#39;source&#39;);var target = document.getElementById(&#39;target&#39;);
source.ondragstart = function(e){
  e.dataTransfer.setData('text','传递文本数据');
}
target.ondragover = function(e){
  e.preventDefault();
}
target.ondrop = function(e){
  console.log(e.dataTransfer.getData('text'));
}
Nach dem Login kopieren

Drag-and-Drop-Einstellungen

Es gibt zwei wichtige in dataTransfer Attributes
dropEffect und effectAllowed

dropEffect

dropEffect-Attributwert ist eine Zeichenfolge, die angibt, welche Platzierung das gezogene Element durchführen kann. Verhalten
Um dieses Attribut zu verwenden, müssen Sie

festlegen
  • keine im Dragenter-Ereignishandler Elemente können hier nicht per Drag & Drop gezogen werden (Standardwert für alle Elemente außer Textfelder)

  • Verschieben zum Ziel

  • Kopie zum Ziel kopieren

  • Link-Ziel öffnet das Drag-Element (das Drag-Element muss ein Link sein und eine URL haben)

effectAllowed

Das effectAllowed-Attribut value ist auch eine Zeichenfolge, die angibt, welcher dropEffect das Element ziehen darf
Um dieses Attribut zu verwenden, müssen Sie es in der Dragst-Ereignishandlerfunktion festlegen

  • nicht initialisiert Kein Ziehen und Drop-Verhalten ist festgelegt

  • none kann durch kein Verhalten verursacht werden

  • kopieren Nur dropEffect-Wert ist zulässig kopieren

  • Link Nur der DropEffect-Wert ist zulässig. Link

  • Verschieben ermöglicht nur das Verschieben des DropEffect-Werts.

  • CopyLink ermöglicht das Kopieren des DropEffect-Werts und verknüpfen

  • copyMove ermöglicht das Kopieren und Verschieben von dropEffect-Werten

  • linkMove ermöglicht das Verknüpfen und Verschieben von dropEffect-Werten

  • alle erlaubt jeden DropEffect

Das obige ist der detaillierte Inhalt vonEine detaillierte Einführung in APIs im Zusammenhang mit dem Drag-and-Drop von HTML5-Elementen (Bilder und Text). 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)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate 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)

Tabellenrahmen in HTML Tabellenrahmen in HTML Sep 04, 2024 pm 04:49 PM

Anleitung zum Tabellenrahmen in HTML. Hier besprechen wir verschiedene Möglichkeiten zum Definieren von Tabellenrändern anhand von Beispielen für den Tabellenrand in HTML.

HTML-Rand links HTML-Rand links Sep 04, 2024 pm 04:48 PM

Anleitung zum HTML-Rand links. Hier besprechen wir einen kurzen Überblick über HTML margin-left und seine Beispiele sowie seine Code-Implementierung.

Verschachtelte Tabelle in HTML Verschachtelte Tabelle in HTML Sep 04, 2024 pm 04:49 PM

Dies ist eine Anleitung für verschachtelte Tabellen in HTML. Hier diskutieren wir anhand der entsprechenden Beispiele, wie man eine Tabelle innerhalb der Tabelle erstellt.

HTML-Tabellenlayout HTML-Tabellenlayout Sep 04, 2024 pm 04:54 PM

Leitfaden zum HTML-Tabellenlayout. Hier besprechen wir die Werte des HTML-Tabellenlayouts zusammen mit den Beispielen und Ausgaben im Detail.

HTML-Eingabeplatzhalter HTML-Eingabeplatzhalter Sep 04, 2024 pm 04:54 PM

Leitfaden für HTML-Eingabeplatzhalter. Hier besprechen wir die Beispiele für HTML-Eingabeplatzhalter zusammen mit den Codes und Ausgaben.

HTML-geordnete Liste HTML-geordnete Liste Sep 04, 2024 pm 04:43 PM

Leitfaden zur HTML-geordneten Liste. Hier besprechen wir auch die Einführung von HTML-geordneten Listen und Typen sowie deren Beispiele

Text in HTML verschieben Text in HTML verschieben Sep 04, 2024 pm 04:45 PM

Anleitung zum Verschieben von Text in HTML. Hier besprechen wir eine Einführung, wie Marquee-Tags funktionieren, mit Syntax und Beispielen für die Implementierung.

HTML-Onclick-Button HTML-Onclick-Button Sep 04, 2024 pm 04:49 PM

Anleitung zum HTML-OnClick-Button. Hier diskutieren wir deren Einführung, Funktionsweise, Beispiele und Onclick-Events in verschiedenen Veranstaltungen.

See all articles