Heim Web-Frontend js-Tutorial Eine Einführung in JavaScript-Entwurfsmuster und -praktiken in Frameworks

Eine Einführung in JavaScript-Entwurfsmuster und -praktiken in Frameworks

Feb 07, 2017 pm 02:09 PM
javascript 框架 设计模式

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)
    }
 }
Nach dem Login kopieren

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)
   }
}
Nach dem Login kopieren

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
Nach dem Login kopieren

  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});
Nach dem Login kopieren

 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)
   }
}
Nach dem Login kopieren

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')
Nach dem Login kopieren

Die Praxis des Dekoratormodus in React-Redux

//装饰器
@connect(state=>state)
class Container extends Component{
  render(){
     return JSON.stringify(this.props)   
   }
}
Nach dem Login kopieren


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 bewerten Sie die Kosteneffizienz der kommerziellen Unterstützung für Java-Frameworks So bewerten Sie die Kosteneffizienz der kommerziellen Unterstützung für Java-Frameworks Jun 05, 2024 pm 05:25 PM

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.

Wie ist die Lernkurve von PHP-Frameworks im Vergleich zu anderen Sprach-Frameworks? Wie ist die Lernkurve von PHP-Frameworks im Vergleich zu anderen Sprach-Frameworks? Jun 06, 2024 pm 12:41 PM

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.

Wie wirken sich die Lightweight-Optionen von PHP-Frameworks auf die Anwendungsleistung aus? Wie wirken sich die Lightweight-Optionen von PHP-Frameworks auf die Anwendungsleistung aus? Jun 06, 2024 am 10:53 AM

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

So wählen Sie das beste Golang-Framework für verschiedene Anwendungsszenarien aus So wählen Sie das beste Golang-Framework für verschiedene Anwendungsszenarien aus Jun 05, 2024 pm 04:05 PM

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.

Detaillierte praktische Erklärung der Golang-Framework-Entwicklung: Fragen und Antworten Detaillierte praktische Erklärung der Golang-Framework-Entwicklung: Fragen und Antworten Jun 06, 2024 am 10:57 AM

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.

Was sind die häufigsten Missverständnisse im Lernprozess des Golang-Frameworks? Was sind die häufigsten Missverständnisse im Lernprozess des Golang-Frameworks? Jun 05, 2024 pm 09:59 PM

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.

Was sind die allgemeinen Dinge, auf die bei der Verwendung des Golang-Frameworks geachtet werden muss? Was sind die allgemeinen Dinge, auf die bei der Verwendung des Golang-Frameworks geachtet werden muss? Jun 06, 2024 pm 01:33 PM

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.

Anwendung von Designmustern im MyBatis-Framework Anwendung von Designmustern im MyBatis-Framework Jun 06, 2024 pm 04:16 PM

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.

See all articles