Teach you how to implement the observer mode in Javascript

Teach you how to implement the observer mode in Javascript

What is the Observer Pattern?

  • Observer pattern is a design pattern.
  • The observer pattern defines a one-to-many dependency relationship between objects. When the state of an object changes, all objects that depend on it will be notified and automatically updated.
  • To put it simply, in the observer pattern, there are two models, an observer and an observed. When the observed object changes or transforms, the observer is notified.

Scenario simulation

  • If Double 11 is coming, people who want to buy goods on Double 11 are observers.
  • The product you want to buy is the observed
  • To make it more vivid, add a merchant to change the price of the product. The merchant is also the publisher (Publish)
  • On the day of Double 11, the merchant (Publisher) will modify the price of the product (Observed), and then the person who subscribes to the product (Observer) will receive a notification.

insert image description here

Code Implementation

//Observer design pattern //Publisher-->Merchant var shopObj = {};
//Product list [key:[]], key is the product name shopObj.list = [];
//Subscription method shopObj.listen = function ( key, fn) { // key is the product model, fn is the subscription behavior if (!this.list[key]) {
        this.list[key] = [];
    }
    this.list[key].push(fn); //Add a subscription to the product list with the product name key}
//Publish message method shopObj.publish = function (key) {
    //var key = arguments[0]; //If you don't pass the parameter key, you can also do this var fns = this.list[key];
    // for (var i = 0; i < fns.length; i++) {
        for(var i = 0 ,fn; fn = fns[i++];){
        //Execute the subscribed function fn arguemnts to store all arguments // var fn = fns[i++];
        fn.apply(this, arguments)
    }
}
// User A adds a subscriptionshopObj.listen("Huawei", function (brand, model) {
    console.log("User A received: " + brand + model + "The price of the mobile phone has been reduced");
})
// User B adds subscription shopObj.listen("Huawei", function (brand, model) {
    console.log("User B received: " + brand + model + "The price of the mobile phone has been reduced");
})
//c user adds subscriptionshopObj.listen("小米", function (brand, model) {
    console.log("User C received: " + brand + model + "The price of the mobile phone has been reduced");
})
//Double 11 merchants publish information about Huawei's price cutsshopObj.publish("Huawei", "p30");
shopObj.publish("小米", "Mix4");

insert image description here

Refactoring the code

//Observer design pattern var Eevent = {
    //Product list [key:[]], key is the product name list: [],
    //Subscription method listen: function (key, fn) { // key is the product model, fn is the subscription behavior if (!this.list[key]) {
            this.list[key] = [];
        }
        this.list[key].push(fn);
    },
    //Publish message method publish: function (key) {
        //var key = arguments[0]; //If you don't pass the parameter key, you can also do this var fns = this.list[key];
        // for (var i = 0; i < fns.length; i++) {
        for (var i = 0, fn; fn = fns[i++];) {
            //Execute the subscribed function fn arguemnts to store all arguments // var fn = fns[i++];
            fn.apply(this, arguments)
        }
    }
}
//Observer object initialization var initEvent = function (obj) {
    for (var i in Eevent) {
        obj[i] = Eevent[i];
    }
}
//Publisher->Merchant var shopObj = {};
initEvent(shopObj);
// User A adds a subscriptionshopObj.listen("Huawei", function (brand, model) {
    console.log("User A received: " + brand + model + "The price of the mobile phone has been reduced");
})
// User B adds subscription shopObj.listen("Huawei", function (brand, model) {
    console.log("User B received: " + brand + model + "The price of the mobile phone has been reduced");
})
//c user adds subscriptionshopObj.listen("小米", function (brand, model) {
    console.log("User C received: " + brand + model + "The price of the mobile phone has been reduced");
})
//Double 11 merchants publish information about Huawei's price cutsshopObj.publish("Huawei", "p30");
shopObj.publish("小米", "Mix4");

insert image description here

Summarize

This article ends here. I hope it can be helpful to you. I also hope you can pay more attention to more content on 123WORDPRESS.COM!

You may also be interested in:
  • Introduction and use of js observer mode
  • How to implement the observer pattern in JavaScript
  • js observer mode bullet screen case
  • JavaScript design pattern: observer mode and publish-subscribe mode detailed explanation
  • JavaScript Design Patterns – Observer Pattern Principles and Usage Examples
  • Simple example of observer and subscriber mode implemented in native js
  • JavaScript Observer Pattern Principles and Usage Examples

<<:  Analysis of the process of publishing and deploying Spring Boot applications through Docker

>>:  6 tips for web design

Recommend

JavaScript canvas to load pictures

This article shares the specific code of JavaScri...

React method of displaying data in pages

Table of contents Parent component listBox List c...

Do designers need to learn to code?

Often, after a web design is completed, the desig...

Linux common basic commands and usage

This article uses examples to illustrate common b...

Steps to package and deploy the Vue project to the Apache server

In the development environment, the vue project i...

Vue3 uses axios interceptor to print front-end logs

Table of contents 1. Introduction 2. Use axios in...

Summarize how to optimize Nginx performance under high concurrency

Table of contents Features Advantages Installatio...

How to create a MySQL master-slave database using Docker on MacOS

1. Pull the MySQL image Get the latest MySQL imag...

Detailed explanation of MySQL transaction processing usage and example code

MySQL transaction support is not bound to the MyS...

Import backup between mysql database and oracle database

Import the data exported from the Oracle database...

JavaScript realizes the queue structure process

Table of contents 1. Understanding Queues 2. Enca...

Summary of 28 common JavaScript string methods and usage tips

Table of contents Preface 1. Get the length of a ...

A comprehensive summary of frequently used statements in MySQL (must read)

The knowledge points summarized below are all fre...

Various types of MySQL indexes

What is an index? An index is a data structure th...

How many times will multiple setStates in React be called?

Table of contents 1. Two setState, how many times...