Heim Web-Frontend js-Tutorial Was sind die Regeln für die Ereignisbehandlung in der Webentwicklung?

Was sind die Regeln für die Ereignisbehandlung in der Webentwicklung?

Jun 04, 2018 am 10:14 AM
web Welche

Dieses Mal werde ich Ihnen die Regeln für die Ereignisbehandlung in der Webentwicklung und die Vorsichtsmaßnahmen für die Ereignisbehandlung in der Webentwicklung vorstellen. Das Folgende ist ein praktischer Fall. Werfen wir einen Blick darauf.

Ereignisverarbeitung

Wir wissen, dass das Ereignis--Objekt (Ereignisobjekt) beispielsweise als Rückrufparameter an den Ereignishandler übergeben wird :

// 不好的写法function handleClick(event) {  var pop = 
document
.getElementById('popup');
  popup.style.left = event.clientX + 'px';
  popup.style.top = event.clientY + 'px';
  popup.className = 'reveal';
}// 你应该明白addListener函数的意思addListener(element, 'click', handleClick);
Nach dem Login kopieren

Dieser Code verwendet nur zwei Attribute des Ereignisobjekts: clientX und clientY. Verwenden Sie diese beiden Attribute, um das Element zu positionieren, bevor es auf der Seite angezeigt wird. Obwohl dieser Code sehr einfach aussieht und keine Probleme aufweist, ist er eigentlich eine schlechte Art, ihn zu schreiben, da dieser Ansatz seine Grenzen hat.

Regel 1: Anwendungslogik isolieren

Das erste Problem mit dem obigen Beispielcode besteht darin, dass der Ereignishandler Anwendungslogik enthält. Anwendungslogik ist funktionaler Code, der sich auf die Anwendung bezieht, nicht auf das Benutzerverhalten. Die Anwendungslogik im obigen Beispielcode besteht darin, ein Popup-Fenster an einer bestimmten Stelle anzuzeigen. Obwohl diese Interaktion stattfinden sollte, wenn der Benutzer auf ein bestimmtes Element klickt, ist dies nicht immer der Fall.

Es ist eine bewährte Vorgehensweise, die Anwendungslogik von allen Event-Handlern zu trennen, da Sie nie wissen, wann dieselbe Logik an anderer Stelle ausgelöst wird. Manchmal müssen Sie beispielsweise festlegen, ob ein Popup-Fenster angezeigt werden soll, wenn der Benutzer die Maus über ein Element bewegt, oder ob beim Drücken einer bestimmten Taste auf der Tastatur die gleiche logische Entscheidung getroffen werden soll. Auf diese Weise führen mehrere Event-Handler dieselbe Logik aus, Ihr Code wird jedoch versehentlich mehrmals kopiert.

Ein weiterer Nachteil der Platzierung von Anwendungslogik in Event-Handlern hängt mit dem Testen zusammen. Beim Testen müssen Sie den Funktionscode direkt auslösen, anstatt einen Klick auf das Element zu simulieren. Wenn Ihre Anwendungslogik in einem Ereignishandler platziert ist, besteht die einzige Möglichkeit, sie zu testen, darin, das Ereignis auszulösen. Obwohl einige Test-Frameworks auslösende Ereignisse simulieren können, ist dies in der Praxis nicht der beste Testansatz. Funktionscode lässt sich am besten mit einem einzigen Funktionsaufruf aufrufen.

Sie müssen Anwendungslogik und Ereignisverarbeitungscode immer trennen. Wenn Sie den vorherigen Beispielcode umgestalten möchten, besteht der erste Schritt darin, den Code, der die Popup-Box-Logik verarbeitet, in eine separate Funktion einzufügen. Diese Funktion wird wahrscheinlich auf einem für die Anwendung definierten globalen Objekt bereitgestellt. Der Event-Handler sollte sich immer im selben globalen Objekt befinden, daher gibt es zwei Methoden.

// 好的写法 - 拆分应用逻辑var MyApplication = {  handleClick: function (event) {    this.showPopup(event);
  },  showPopup: function (event) {    var pop = document.getElementById('popup');
    popup.style.left = event.clientX + 'px';
    popup.style.top = event.clientY + 'px';
    popup.className = 'reveal';
  }
};
addListener(element, 'click', function (event) {
  MyApplication.handleClick(event);
});
Nach dem Login kopieren

Die gesamte Anwendungslogik, die zuvor in Event-Handlern enthalten war, wird jetzt in die Methode MyApplication.showPopup() verschoben. Jetzt führt die MyApplication.handleClick()-Methode nur noch eine Aufgabe aus, nämlich den Aufruf von MyApplication.showPopup(). Wenn die Anwendungslogik entfernt wird, können Aufrufe desselben Funktionscodes an mehreren Stellen erfolgen, und es besteht keine Notwendigkeit, sich auf die Auslösung eines bestimmten Ereignisses zu verlassen, was offensichtlich praktischer ist. Dies ist jedoch nur der erste Schritt zur Aufschlüsselung des Event-Handler-Codes.

Regel 2: Ereignisobjekte nicht verteilen

Nach dem Entfernen der Anwendungslogik besteht im obigen Beispielcode immer noch ein Problem, d. h. Ereignisobjekte werden unkontrolliert verteilt. Es übergibt MyApplication.handleClick() vom anonymen Ereignishandler, der es dann an MyApplication.showPopup() weitergibt. Wie oben erwähnt, enthält das Ereignisobjekt viele zusätzliche Informationen zum Ereignis, und dieser Code verwendet nur zwei davon. Die Anwendungslogik sollte sich aus folgenden Gründen nicht darauf verlassen, dass das Ereignisobjekt die Funktion ordnungsgemäß ausführt: Die

-Methodenschnittstelle gibt nicht an, welche Daten erforderlich sind. Eine gute API muss hinsichtlich Erwartungen und Abhängigkeiten transparent sein. Wenn Sie ein Ereignisobjekt als Parameter übergeben, erfahren Sie nicht, welche Eigenschaften des Ereignisses nützlich sind und wofür sie verwendet werden.

Wenn Sie diese Methode testen möchten, müssen Sie daher ein Ereignisobjekt neu erstellen und übergeben als Parameter eingeben. Daher müssen Sie genau wissen, welche Informationen diese Methode verwendet, damit Sie den Testcode korrekt schreiben können.

Diese Probleme (bezogen auf unklares Schnittstellenformat und selbst erstellte Ereignisobjekte zum Testen) sind in großen Webanwendungen nicht ratsam. Unklarheit im Code kann zu Fehlern führen.

Der beste Weg besteht darin, den Ereignishandler das Ereignisobjekt verwenden zu lassen, um das Ereignis zu verarbeiten, und dann alle erforderlichen Daten abzurufen und an die Anwendungslogik zu übergeben. Beispielsweise erfordert die Methode MyApplication.showPopup() nur zwei Datenelemente, die x-Koordinate und die y-Koordinate. Auf diese Weise werden wir die Methode so umschreiben, dass sie diese beiden Parameter erhält.

// 好的写法var MyApplication = {  handleClick: function (event) {    this.showPopup(event.clientX, event.clientY);
  },  showPopup: function (x, y) {    var pop = document.getElementById('popup');
    popup.style.left = x + 'px';
    popup.style.top = y + 'px';
    popup.className = 'reveal';
  }
};
addListener(element, 'click', function (event) {
  MyApplication.handleClick(event);
});
Nach dem Login kopieren

在这段新重写的代码中,MyApplication.handleClick()将x坐标和y坐标传入了MyApplication.showPopup(),代替了之前传入的事件对象。可以很清晰地看到MyApplication.showPopup()所期望传入的参数,并且在测试或代码的任意位置都可以很轻易地直接调用这段逻辑,比如:

// 这样调用非常棒MyApplication.showPopup(10, 10);

当处理事件时,最好让事件处理程序成为接触到event对象的唯一的函数。事件处理程序应当在进入应用逻辑之前针对event对象执行任何必要的操作,包括阻止默认事件或阻止事件冒泡,都应当直接包含在事件处理程序中。比如:

// 好的写法var MyApplication = {  handleClick: function (event) {    // 假设事件支持DOM Level2
    event.preventDefault();
    event.stopPropagation();    // 传入应用逻辑
    this.showPopup(event.clientX, event.clientY);
  },  showPopup: function (x, y) {    var pop = document.getElementById('popup');
    popup.style.left = x + 'px';
    popup.style.top = y + 'px';
    popup.className = 'reveal';
  }
};
addListener(element, 'click', function (event) {
  MyApplication.handleClick(event);
});
Nach dem Login kopieren

在这段代码中,MyApplication.handleClick()是事件处理程序,因此它在将数据传入应用逻辑之前调用了event.preventDefault()和event.stopPropagation(),这清除地展示了事件处理程序和应用逻辑之间的分工。因为应用逻辑不需要对event产生依赖,进而在很多地方都可以轻松地使用相同的业务逻辑,包括写测试代码。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

怎样利用JS做出引用传递与值传递

如何做出node.js界面

Das obige ist der detaillierte Inhalt vonWas sind die Regeln für die Ereignisbehandlung in der Webentwicklung?. 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)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
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)

So verwenden Sie Python + Flask, um Echtzeitaktualisierungen und die Anzeige von Protokollen auf Webseiten zu realisieren So verwenden Sie Python + Flask, um Echtzeitaktualisierungen und die Anzeige von Protokollen auf Webseiten zu realisieren May 17, 2023 am 11:07 AM

1. Protokollausgabe in eine Datei mithilfe des Moduls: Die Protokollierung kann ein Protokoll auf benutzerdefinierter Ebene generieren und das Protokoll auf einem angegebenen Pfad ausgeben: debug (Debug-Protokoll) = 5) {clearTimeout (Zeit) // Wenn alle Ergebnisse erhalten wurden, 10 Aufeinanderfolgende Zeiten sind leer Protokolllöschung geplante Aufgabe}return}if(data.log_type==2){//Wenn ein neues Protokoll abgerufen wird for(i=0;i

So verwenden Sie den Nginx-Webserver-Caddy So verwenden Sie den Nginx-Webserver-Caddy May 30, 2023 pm 12:19 PM

Einführung in Caddy Caddy ist ein leistungsstarker und hoch skalierbarer Webserver, der derzeit über 38.000 Sterne auf Github hat. Caddy ist in der Go-Sprache geschrieben und kann für statisches Ressourcen-Hosting und Reverse-Proxy verwendet werden. Caddy verfügt über die folgenden Hauptfunktionen: Im Vergleich zur komplexen Konfiguration von Nginx ist die ursprüngliche Caddyfile-Konfiguration sehr einfach. Sie kann die Konfiguration über die bereitgestellte AdminAPI dynamisch ändern. Sie unterstützt standardmäßig die automatisierte HTTPS-Konfiguration und kann automatisch HTTPS-Zertifikate beantragen und konfigurieren Sie sie; es kann auf Zehntausende von Websites erweitert werden, ohne dass zusätzliche Abhängigkeiten in der Go-Sprache geschrieben werden müssen; die Speichersicherheit ist besser gewährleistet. Zunächst installieren wir es direkt in CentO

Welche Spiele eignen sich zum Spielen mit i34150 und 1G-unabhängiger Grafik (welche Spiele sind für i34150 geeignet) Welche Spiele eignen sich zum Spielen mit i34150 und 1G-unabhängiger Grafik (welche Spiele sind für i34150 geeignet) Jan 05, 2024 pm 08:24 PM

Welche Spiele können mit dem i34150 mit 1G-unabhängiger Grafik gespielt werden? Kann er kleine Spiele wie LoL spielen? GTX750 und GTX750TI sind sehr geeignete Grafikkarten. Wenn Sie nur ein paar kleine Spiele spielen oder keine Spiele spielen, empfiehlt sich die Verwendung der integrierten i34150-Grafikkarte. Im Allgemeinen ist der Preisunterschied zwischen Grafikkarten und Prozessoren nicht sehr groß, daher ist es wichtig, eine vernünftige Kombination zu wählen. Wenn Sie 2 GB Videospeicher benötigen, wird empfohlen, GTX750TI zu wählen. Wenn Sie nur 1 GB Videospeicher benötigen, wählen Sie einfach GTX750. Die GTX750TI kann als verbesserte Version der GTX750 mit Übertaktungsfunktionen angesehen werden. Welche Grafikkarte mit dem i34150 gekoppelt werden kann, hängt von Ihren Anforderungen ab. Wenn Sie eigenständige Spiele spielen möchten, empfiehlt es sich, einen Wechsel der Grafikkarte in Betracht zu ziehen. du kannst wählen

Verwendung von Jetty7 für die Webserververarbeitung in der Java-API-Entwicklung Verwendung von Jetty7 für die Webserververarbeitung in der Java-API-Entwicklung Jun 18, 2023 am 10:42 AM

Verwendung von Jetty7 für die Webserververarbeitung in der JavaAPI-Entwicklung Mit der Entwicklung des Internets ist der Webserver zum Kernbestandteil der Anwendungsentwicklung geworden und steht auch im Fokus vieler Unternehmen. Um den wachsenden Geschäftsanforderungen gerecht zu werden, entscheiden sich viele Entwickler für die Verwendung von Jetty für die Webserverentwicklung, und seine Flexibilität und Skalierbarkeit sind weithin anerkannt. In diesem Artikel wird erläutert, wie Sie Jetty7 für die Webentwicklung in der JavaAPI-Entwicklung verwenden.

Echtzeitschutz vor Gesichtsblockierungsangriffen im Web (basierend auf maschinellem Lernen) Echtzeitschutz vor Gesichtsblockierungsangriffen im Web (basierend auf maschinellem Lernen) Jun 10, 2023 pm 01:03 PM

Gesichtsblockierendes Sperrfeuer bedeutet, dass eine große Anzahl von Sperrfeuern vorbeischwebt, ohne die Person im Video zu blockieren, sodass es aussieht, als würden sie hinter der Person schweben. Maschinelles Lernen erfreut sich seit mehreren Jahren großer Beliebtheit, aber viele Menschen wissen nicht, dass diese Funktionen auch in Browsern ausgeführt werden können. Dieser Artikel stellt den praktischen Optimierungsprozess in Videosperren vor diese Lösung, in der Hoffnung, einige Ideen zu öffnen. mediapipeDemo (https://google.github.io/mediapipe/) demonstriert das Implementierungsprinzip des On-Demand-Uploads mit Gesichtsblockierung. Die Hintergrundberechnung des Videoservers extrahiert den Porträtbereich im Videobildschirm und konvertiert ihn in SVG Speichern, während der Client das Video abspielt. Laden Sie SVG vom Server herunter und kombinieren Sie es mit Barrage, Portrait

So konfigurieren Sie Nginx, um sicherzustellen, dass der FRP-Server und das Web Port 80 gemeinsam nutzen So konfigurieren Sie Nginx, um sicherzustellen, dass der FRP-Server und das Web Port 80 gemeinsam nutzen Jun 03, 2023 am 08:19 AM

Zunächst werden Sie Zweifel haben: Was ist FRP? Einfach ausgedrückt ist frp ein Intranet-Penetrationstool. Nach der Konfiguration des Clients können Sie über den Server auf das Intranet zugreifen. Jetzt hat mein Server Nginx als Website verwendet und es gibt nur einen Port 80. Was soll ich also tun, wenn der FRP-Server auch Port 80 verwenden möchte? Nach der Abfrage kann dies durch die Verwendung des Reverse-Proxys von Nginx erreicht werden. Hinzufügen: frps ist der Server, frpc ist der Client. Schritt 1: Ändern Sie die Konfigurationsdatei nginx.conf auf dem Server und fügen Sie die folgenden Parameter zu http{} in nginx.conf hinzu: server{listen80

So implementieren Sie die Formularvalidierung für Webanwendungen mit Golang So implementieren Sie die Formularvalidierung für Webanwendungen mit Golang Jun 24, 2023 am 09:08 AM

Die Formularvalidierung ist ein sehr wichtiger Link bei der Entwicklung von Webanwendungen. Sie kann die Gültigkeit der Daten vor dem Absenden der Formulardaten überprüfen, um Sicherheitslücken und Datenfehler in der Anwendung zu vermeiden. Die Formularvalidierung für Webanwendungen kann einfach mit Golang implementiert werden. In diesem Artikel wird erläutert, wie Sie mit Golang die Formularvalidierung für Webanwendungen implementieren. 1. Grundelemente der Formularvalidierung Bevor wir uns mit der Implementierung der Formularvalidierung befassen, müssen wir die Grundelemente der Formularvalidierung kennen. Formularelemente: Formularelemente sind

So aktivieren Sie den administrativen Zugriff über die Cockpit-Web-Benutzeroberfläche So aktivieren Sie den administrativen Zugriff über die Cockpit-Web-Benutzeroberfläche Mar 20, 2024 pm 06:56 PM

Cockpit ist eine webbasierte grafische Oberfläche für Linux-Server. Es soll vor allem neuen/erfahrenen Benutzern die Verwaltung von Linux-Servern erleichtern. In diesem Artikel besprechen wir die Cockpit-Zugriffsmodi und wie Sie den Administratorzugriff von CockpitWebUI auf das Cockpit umstellen. Inhaltsthemen: Cockpit-Eingabemodi Ermitteln des aktuellen Cockpit-Zugriffsmodus Aktivieren des Verwaltungszugriffs für das Cockpit über CockpitWebUI Deaktivieren des Verwaltungszugriffs für das Cockpit über CockpitWebUI Fazit Cockpit-Eingabemodi Das Cockpit verfügt über zwei Zugriffsmodi: Eingeschränkter Zugriff: Dies ist die Standardeinstellung für den Cockpit-Zugriffsmodus. In diesem Zugriffsmodus können Sie vom Cockpit aus nicht auf den Webbenutzer zugreifen

See all articles