


Eine Einführung in JavaScript-Entwurfsmuster und -praktiken in Frameworks
Beim Schreiben von JS- und Assemblercode kann die Verwendung bestimmter Entwurfsmuster unseren Code eleganter und flexibler machen.
Als Nächstes gibt Ihnen der Autor eine kurze Einführung in die Verwendung von Entwurfsmustern in diesen Bibliotheken, Grammatiken und Frameworks durch die Kombination von subscribe mit redux, class in ES6, $dispatch in vue und on/off in jquery .
Durch Designmuster gelöste Probleme
Designmuster sind kein sehr mysteriöses Wissen. Viele Studenten haben beim Schreiben von JS-Code versehentlich viele Designmuster verwendet.
Der Autor glaubt, dass das Abstrahieren von Entwurfsmustern, um sie separat zu diskutieren, genauso ist wie das Abstrahieren von Blasen und das Sortieren von Algorithmen, um ein häufig verwendetes JS-Muster zu beschreiben.
Indem Sie diese Art von Muster studieren, lassen Sie das Muster unsere Codestruktur und unseren JS-Algorithmus leiten.
Ein Überblick über einige häufig verwendete Entwurfsmuster
Beobachter [Beobachtermodus]
Aktives Auslösen des Rückrufverhaltens der Beobachterwarteschlange und der HashMap gemäß Statusänderungen
Eine einfache Code-Praxis für Beobachtermuster
class StateTracker{ constructor(){ this.observers = []; this.internamState= 10; } // 改变内部状态,触发状态的观察者列表 change(val){ this.internamState= val; this.observers.forEach(observer=>observer(val)); } registerObserver(ObserverFn){ this.obserers.push(ObserverFn) } }
Veröffentlichen/Abonnieren [Abonnement-Veröffentlichungsmodus]
Speichern Sie die Themen-/Rückrufform von hashMap im gemeinsam genutzten Zugriffsbereich des Codemoduls.
Fügen Sie Ein/Aus/Trigger und andere Schnittstellen hinzu, um Aktionen wie Montage, Entfernung und Auslösung zu implementieren.
Eine einfache Code-Praxis zum Abonnement und Veröffentlichen
class PubSubHandler{ constructor(){ this.eventPool = {}; } //移除 off(topicName){ delete this.observers[topicName] } //发布 trigger(topicName,...args){ this.eventPool[topicName] && this.eventPool[topicName].forEach(callback=>callback(...args)); } //订阅 on(topicName,callback){ let topic = this.eventPool[topicName] ; if(!topic){ this.eventPool[topicName] =[] } this.eventPool[topicName].push(callback) } }
Singleton [Einzelfallmodus]
Es gibt nur eine Instanz des Konstruktors, und die interne Instanz wird normalerweise gespeichert Greifen Sie über einen Abschluss über die Schnittstelle auf die interne Instanz zu.
var singleton = ()=>{ var instance; var createInstance = ()=>{ this.a = 1; this.b = 2; } return { getInstance:()=>{ if(!instance){ instance = createInstance(); } return instance; } } } var test = singleton(); test.getInstance() == test.getInstance() //true
Decorator-Hybridmodus
Dieser Modus dient dazu, mehr Verhaltensweisen auf dem Originalobjekt zu dekorieren und den Variablennamen unverändert zu lassen. Wenn Sie @decorator oder Python und andere Sprachen von ES7 verwendet haben, sollten Sie mit Decorator vertraut sein.
function decorator(sourceObj,decortorFn){ decortorFn(sourceObj); return sourceObj } var d = {a:1}; // d变为了{a:1,b:1} d = decorator(d,(d)=>{d.b=1});
Mixin-Mischmodus
Dieser Modus ähnelt in gewisser Weise dem Dekorator, außer dass seine Funktion eher vertikal ist. Dabei handelt es sich um den Vorgang des Hinzufügens und Überschreibens von Objekten über den ursprünglichen Objekten. Im Vergleich zu Methoden wie Extens und Object.assign ist der Mixin-Modus ausdrucksvoller. Mixin-Muster können nicht verallgemeinert werden. Es kann verschiedene Mixin-Strategien geben, die auf unterschiedlichen Datentypen basieren.
class StateTracker{ constructor(){ this.raw = { a:1, b:2 } } mixin(obj){ Object.assign(this.raw,obj) } }
auf häufig verwendete Frameworks, Grammatiken und Bibliotheken usw., um die Anwendung dieser Entwurfsmuster zu veranschaulichen.
Die Verwendung des Beobachtermodus in Redux
var store = createStore(reducer,initialState);//注册redux store,存储在 nextListeners数组 var test = store.subscribe(()=>{console.log('我注册了!')});// 取消注册监听 test.unsubscribe(); publish/subscribe在jquery中的使用 $(document).on('hello',()=>{console.log('hello')})$(document).trigger('hello');$(document).off('hello')
Die Praxis des Dekoratormodus in React-Redux
//装饰器 @connect(state=>state) class Container extends Component{ render(){ return JSON.stringify(this.props) } }

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

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

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die Bewertung des Kosten-/Leistungsverhältnisses des kommerziellen Supports für ein Java-Framework umfasst die folgenden Schritte: Bestimmen Sie das erforderliche Maß an Sicherheit und Service-Level-Agreement-Garantien (SLA). Die Erfahrung und das Fachwissen des Forschungsunterstützungsteams. Erwägen Sie zusätzliche Services wie Upgrades, Fehlerbehebung und Leistungsoptimierung. Wägen Sie die Kosten für die Geschäftsunterstützung gegen Risikominderung und Effizienzsteigerung ab.

Die Lernkurve eines PHP-Frameworks hängt von Sprachkenntnissen, Framework-Komplexität, Dokumentationsqualität und Community-Unterstützung ab. Die Lernkurve von PHP-Frameworks ist im Vergleich zu Python-Frameworks höher und im Vergleich zu Ruby-Frameworks niedriger. Im Vergleich zu Java-Frameworks haben PHP-Frameworks eine moderate Lernkurve, aber eine kürzere Einstiegszeit.

Das leichte PHP-Framework verbessert die Anwendungsleistung durch geringe Größe und geringen Ressourcenverbrauch. Zu seinen Merkmalen gehören: geringe Größe, schneller Start, geringer Speicherverbrauch, verbesserte Reaktionsgeschwindigkeit und Durchsatz sowie reduzierter Ressourcenverbrauch. Praktischer Fall: SlimFramework erstellt eine REST-API, nur 500 KB, hohe Reaktionsfähigkeit und hoher Durchsatz

Wählen Sie das beste Go-Framework basierend auf Anwendungsszenarien aus: Berücksichtigen Sie Anwendungstyp, Sprachfunktionen, Leistungsanforderungen und Ökosystem. Gängige Go-Frameworks: Gin (Webanwendung), Echo (Webdienst), Fiber (hoher Durchsatz), gorm (ORM), fasthttp (Geschwindigkeit). Praktischer Fall: Erstellen einer REST-API (Fiber) und Interaktion mit der Datenbank (gorm). Wählen Sie ein Framework: Wählen Sie fasthttp für die Schlüsselleistung, Gin/Echo für flexible Webanwendungen und gorm für die Datenbankinteraktion.

Bei der Go-Framework-Entwicklung treten häufige Herausforderungen und deren Lösungen auf: Fehlerbehandlung: Verwenden Sie das Fehlerpaket für die Verwaltung und Middleware zur zentralen Fehlerbehandlung. Authentifizierung und Autorisierung: Integrieren Sie Bibliotheken von Drittanbietern und erstellen Sie benutzerdefinierte Middleware zur Überprüfung von Anmeldeinformationen. Parallelitätsverarbeitung: Verwenden Sie Goroutinen, Mutexe und Kanäle, um den Ressourcenzugriff zu steuern. Unit-Tests: Verwenden Sie Gotest-Pakete, Mocks und Stubs zur Isolierung sowie Code-Coverage-Tools, um die Angemessenheit sicherzustellen. Bereitstellung und Überwachung: Verwenden Sie Docker-Container, um Bereitstellungen zu verpacken, Datensicherungen einzurichten und Leistung und Fehler mit Protokollierungs- und Überwachungstools zu verfolgen.

Beim Go-Framework-Lernen gibt es fünf Missverständnisse: übermäßiges Vertrauen in das Framework und eingeschränkte Flexibilität. Wenn Sie die Framework-Konventionen nicht befolgen, wird es schwierig, den Code zu warten. Die Verwendung veralteter Bibliotheken kann zu Sicherheits- und Kompatibilitätsproblemen führen. Die übermäßige Verwendung von Paketen verschleiert die Codestruktur. Das Ignorieren der Fehlerbehandlung führt zu unerwartetem Verhalten und Abstürzen.

Bei der Verwendung des Golang-Frameworks sollten Sie Folgendes beachten: Überprüfen Sie, ob die Route mit der Anfrage übereinstimmt, um Routing-Fehler zu vermeiden. Verwenden Sie Middleware mit Vorsicht, um Leistungseinbußen zu vermeiden. Verwalten Sie Datenbankverbindungen ordnungsgemäß, um Leistungsprobleme oder Abstürze zu vermeiden. Verwenden Sie Fehler-Wrapper, um Fehler zu behandeln und sicherzustellen, dass Ihr Code klar und einfach zu debuggen ist. Beziehen Sie Pakete von Drittanbietern aus seriösen Quellen und halten Sie die Pakete auf dem neuesten Stand.

Das MyBatis-Framework wendet in großem Umfang Entwurfsmuster an, darunter: Factory-Modus: erstellt SqlSessionFactory-Objekte, verwaltet Datenbankverbindungen und -abfragen: implementiert verzögertes Laden und verzögertes Laden, um die Leistung zu verbessern; Darstellungsmodus: Kapselt den Datenbankzugriff und vereinfacht die Codewartung. Unter anderem kann die Eins-zu-Viele-Beziehungszuordnung über die Benutzer- und Bestellklassen, die Mapper-Schnittstelle und die MapperXML-Konfiguration implementiert werden, wobei Lazy Loading und verschachtelte resultMap zur Optimierung der Leistung verwendet werden.
