Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

青灯夜游
Freigeben: 2021-11-30 19:34:03
nach vorne
6926 Leute haben es durchsucht

Dieser Artikel bringt Ihnen ein kleines Programm in die Praxis und zeigt Ihnen Schritt für Schritt, wie Sie eine einfache kleine Programmüberwachungsfunktion implementieren. Ich hoffe, dass es für alle hilfreich ist!

... Wenn das Programm einen Fehler meldet, lädt es dann automatisch den Vorgangsdatensatz des Benutzers auf den Server hoch und benachrichtigt den Entwickler, damit er sich darum kümmert?Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

Ich habe später herausgefunden, dass man das Front-End-Monitoring nennt.

Natürlich geht es in diesem Artikel um die relativ einfachen, da ich nicht weiß, wie es geht, und noch nicht an der Entwicklung echter Projekte beteiligt war. .

Was sind die Funktionen dieser kleinen Programmüberwachung?

1) Zeichnen Sie die Zeit auf, zu der der Benutzer die Seite betritt und verlässt.

2) Überwachen Sie alle Klickereignisse.

3) Zeichnen Sie die ungefähre Bewegungsbahn des Benutzers auf.

4) Wenn der Cloud-Funktionsaufruf fehlschlägt, wird er automatisch an die Datenbank gemeldet, um den Entwickler daran zu erinnern, sich darum zu kümmern.

Realisieren Sie die Aufzeichnung von Benutzern, die die Seite betreten und verlassen.


Wir alle wissen, dass das Miniprogramm über mehrere Lebenszyklusfunktionen verfügt. Darunter habe ich mich für die Aufzeichnung in den drei Lebenszyklen onShow, onHide und unload entschieden.

Der dümmere Weg besteht darin, die Seitenanzeige und die Zeit zum Ausblenden/Entladen direkt in der Lebenszyklusfunktion jeder Seite aufzuzeichnen, aber das ist zu repetitiv.

So können wir diesen Lebenszyklusfunktionen eine weitere Ebene hinzufügen (dies wird als „ Dekorationsmuster in Javascript-Designmustern)

Eine neue Frage stellt sich wieder: Wie fügt man allen Ereignissen eine weitere Ebene hinzu?

Werfen wir zunächst einen Blick auf die index.js-Datei einer Seite

Indem wir ein Objekt an die Page-Methode übergeben, Dieses Objekt enthält alle Ereignisse (Klick, Folie, CSS3-Animation usw.) und den Lebenszyklus.

Damit wir eine Methode anpassen können, um die Page-Methode zu ersetzen, Rufen Sie bei dieser Methode das übergebene Objekt ab und ändern Sie es. Denken Sie abschließend daran, die ursprüngliche Seite (Obj) erneut auszuführen. Schauen Sie sich die Codestruktur anMiniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

Der Code ist eigentlich sehr einfach. Sobald die Funktion aufgerufen wird, werden die Informationen der aktuellen Seite an das Array-Element angehängt. Wenn die Array-Länge größer als 10 ist, entfernen Sie das erste Element und belassen Sie die Array-Länge bei 11.

Der Grund, warum ein Timer verwendet wird, liegt darin, dass manchmal die neuesten Daten nicht gelesen werden können, ohne während des Tests einen Timer hinzuzufügen. Rufen Sie die alten Daten ab, ändern Sie sie, weisen Sie sie zu und setzen Sie schließlich den Cache zurück (da bei Ausführung der Onshow-Funktion die Onhide-Funktion der vorherigen Seite möglicherweise nicht abgeschlossen wird und diese Funktion den Cache ändert, ebenso wie die Onshow-Funktion get ist nicht der neueste Cache, was zu Informationsverlust führt Versuchen Sie es, aber es ist zu mühsam.Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

2) Fügen Sie allen Ereignissen auf der Seite eine weitere Ebene hinzu. Wenn das Ereignis ausgelöst wird, gibt es einen Parameter e, beurteilen Sie einfach e.type.

Schauen Sie sich den Code anMiniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion


Kehren Sie den Aufruf schließlich zur ursprünglichen Funktion zurück. Schauen Sie sich als nächstes die Funktion „replaceOld“ an. Sie implementiert das ursprüngliche Ereignis (Dekoratormodus).

Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

Führen Sie die Ersetzungsmethode für jedes Funktionspaar auf der Seite aus.

Was nützt es?

Wir können sehen, dass diese Funktion die ursprüngliche Methode umschließt. Die spezifische Verpackungsmethode hängt von der übergebenen Ersatzfunktion ab.

Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

Diese Funktion gibt schließlich die Ausführung der ursprünglichen Funktion zurück, also den Inhalt des Pakets die Beurteilung innerhalb des Funktionskörpers, ob es sich um ein Klickereignis handelt. Wenn ja, speichern Sie einfach die Daten.

Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-ÜberwachungsfunktionZwischengespeicherte Ergebnisse anzeigen:

Wenn der Cloud-Funktionsaufruf fehlschlägt, wird er automatisch an die Datenbank gemeldet, um den Entwickler daran zu erinnern, sich darum zu kümmern.

Verwenden Sie Object.defineProperty(), um den Cloud-Funktionsaufruf zu kapern, eine weitere Ebene zu umschließen und den Aufruf dann an die Cloud-Funktion zurückzugeben.

Aber hier gibt es einen Punkt, den Sie beachten sollten. Es gibt zwei Möglichkeiten, die Cloud-Funktion aufzurufen,

1) Es wird eine Rückruffunktion übergeben und das Ergebnis wird in der Rückruffunktion abgerufen.

2) Wenn keine Rückruffunktion übergeben wird, wird „await“ verwendet, um auf das Aufrufergebnis zu warten, und wir müssen den Fehler des Cloud-Funktionsaufrufs erfassen,

damit wir das Ergebnis direkt während der Entführung erhalten und dann zurückkehren ein Versprechen.

1Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

Es ist eigentlich sehr einfach, Entwickler automatisch zu benachrichtigen und zu verarbeiten, indem die von WeChat in der Cloud-Funktion bereitgestellte Vorlagennachricht aufgerufen wird.

Schauen Sie sich die zwischengespeicherten Ergebnisse an

1Miniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion

Die Struktur ist möglicherweise etwas chaotisch, schließlich ist es das erste Mal, dass ich sie geschrieben habe, und sie wurde noch nicht angewendet.

【Verwandte Lernempfehlungen:Mini-Tutorial zur Programmentwicklung

Das obige ist der detaillierte Inhalt vonMiniprogramm-Praxis: Implementierung einer einfachen Miniprogramm-Überwachungsfunktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:juejin.cn
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
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!