日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

八種現代 JavaScript 響應式模式

來源: 責編: 時間:2024-05-30 17:20:06 278觀看
導讀響應性本質上是關于系統如何對數據變化作出反應,有不同類型的響應性。然而,在這篇文章中,我們關注的是響應性,即響應數據變化而采取行動。作為一名前端開發者,Pavel Pogosov 每天都要面對這個問題。因為瀏覽器本身是一個完

vs928資訊網——每日最新資訊28at.com

響應性本質上是關于系統如何對數據變化作出反應,有不同類型的響應性。然而,在這篇文章中,我們關注的是響應性,即響應數據變化而采取行動。vs928資訊網——每日最新資訊28at.com

作為一名前端開發者,Pavel Pogosov 每天都要面對這個問題。因為瀏覽器本身是一個完全異步的環境?,F代 Web 界面必須快速響應用戶的操作,這包括更新 UI、發送網絡請求、管理導航和執行各種其他任務。vs928資訊網——每日最新資訊28at.com

盡管人們常常將響應性與框架聯系在一起,Pavel Pogosov 認為通過純 JavaScript 實現響應性可以學到很多。所以,我們將自己編寫一些模式代碼,并研究一些基于響應性的原生瀏覽器 API。vs928資訊網——每日最新資訊28at.com

目錄

  • PubSub(發布-訂閱模式)
  • 自定義事件作為瀏覽器版本的 PubSub
  • 自定義事件目標
  • 觀察者模式
  • 使用 Proxy 的響應式屬性
  • 單個對象屬性和響應性
  • 使用 MutationObserver 的響應式 HTML 屬性
  • 使用 IntersectionObserver 的響應式滾動

1. PubSub(發布-訂閱模式)

class PubSub {  constructor() {    this.subscribers = {};  }  subscribe(event, callback) {    if (!this.subscribers[event]) {      this.subscribers[event] = [];    }    this.subscribers[event].push(callback);  }  // 向特定事件的所有訂閱者發布消息  publish(event, data) {    if (this.subscribers[event]) {      this.subscribers[event].forEach((callback) => {        callback(data);      });    }  }}const pubsub = new PubSub();pubsub.subscribe('news', (message) => {  console.log(`訂閱者1收到了新聞:${message}`);});pubsub.subscribe('news', (message) => {  console.log(`訂閱者2收到了新聞:${message}`);});// 向 'news' 事件發布消息pubsub.publish('news', '最新頭條新聞:...');// 控制臺日志輸出:// 訂閱者1收到了新聞:最新頭條新聞:...// 訂閱者2收到了新聞:最新頭條新聞:...

一個常見的使用示例是 Redux。這款流行的狀態管理庫基于這種模式(或更具體地說,是 Flux 架構)。在 Redux 的上下文中,工作機制相當簡單:vs928資訊網——每日最新資訊28at.com

發布者:store 充當發布者。當一個 action 被派發時,store 會通知所有訂閱的組件狀態的變化。 訂閱者:應用程序中的 UI 組件是訂閱者。它們訂閱 Redux store 并在狀態變化時接收更新。vs928資訊網——每日最新資訊28at.com

自定義事件作為瀏覽器版本的 PubSub

瀏覽器通過 CustomEvent 類和 dispatchEvent 方法提供了一個用于觸發和訂閱自定義事件的 API。后者不僅能讓我們觸發事件,還能附加任何想要的數據。vs928資訊網——每日最新資訊28at.com

const customEvent = new CustomEvent('customEvent', {  detail: '自定義事件數據', // 將所需數據附加到事件});const element = document.getElementById('.element-to-trigger-events');element.addEventListener('customEvent', (event) => {  console.log(`訂閱者1收到了自定義事件:${event.detail}`);});element.addEventListener('customEvent', (event) => {  console.log(`訂閱者2收到了自定義事件:${event.detail}`);});// 觸發自定義事件element.dispatchEvent(customEvent);// 控制臺日志輸出:// 訂閱者1收到了自定義事件:自定義事件數據// 訂閱者2收到了自定義事件:自定義事件數據

自定義事件目標

如果你不想在全局 window 對象上分派事件,可以創建你自己的事件目標。vs928資訊網——每日最新資訊28at.com

通過擴展原生 EventTarget 類,你可以向其新實例分派事件。這確保你的事件僅在新類本身上觸發,避免了全局傳播。此外,你可以直接將處理程序附加到這個特定實例上。vs928資訊網——每日最新資訊28at.com

class CustomEventTarget extends EventTarget {  constructor() {    super();  }  // 觸發自定義事件的自定義方法  triggerCustomEvent(eventName, eventData) {    const event = new CustomEvent(eventName, { detail: eventData });    this.dispatchEvent(event);  }}const customTarget = new CustomEventTarget();// 向自定義事件目標添加事件監聽器customTarget.addEventListener('customEvent', (event) => {  console.log(`自定義事件收到了數據:${event.detail}`);});// 觸發自定義事件customTarget.triggerCustomEvent('customEvent', '你好,自定義事件!');// 控制臺日志輸出:// 自定義事件收到了數據:你好,自定義事件!

觀察者模式

觀察者模式與 PubSub 非常相似。你訂閱 Subject,然后它通知其訂閱者(觀察者)關于變化,使他們能夠做出相應的反應。這種模式在構建解耦和靈活的架構中發揮了重要作用。vs928資訊網——每日最新資訊28at.com

class Subject {  constructor() {    this.observers = [];  }  addObserver(observer) {    this.observers.push(observer);  }  // 從列表中移除觀察者  removeObserver(observer) {    const index = this.observers.indexOf(observer);    if (index !== -1) {      this.observers.splice(index, 1);    }  }  // 通知所有觀察者關于變化  notify() {    this.observers.forEach((observer) => {      observer.update();    });  }}class Observer {  constructor(name) {    this.name = name;  }  // 通知時調用的更新方法  update() {    console.log(`${this.name} 收到了更新。`);  }}const subject = new Subject();const observer1 = new Observer('觀察者1');const observer2 = new Observer('觀察者2');// 將觀察者添加到主體subject.addObserver(observer1);subject.addObserver(observer2);// 通知觀察者關于變化subject.notify();// 控制臺日志輸出:// 觀察者1 收到了更新。// 觀察者2 收到了更新。

使用 Proxy 的響應式屬性

如果你想對對象的變化做出反應,Proxy 是一個好方法。它讓我們在設置或獲取對象字段的值時實現響應性。vs928資訊網——每日最新資訊28at.com

const person = {  name: 'Pavel',  age: 22,};const reactivePerson = new Proxy(person, {  // 攔截設置操作  set(target, key, value) {    console.log(`將 ${key} 設置為 ${value}`);    target[key] = value;    // 表示設置值是否成功    return true;  },  // 攔截獲取操作  get(target, key) {    console.log(`獲取 ${key}`);    return target[key];  },});reactivePerson.name = 'Sergei'; // 將 name 設置為 Sergeiconsole.log(reactivePerson.name); // 獲取 name: SergeireactivePerson.age = 23; // 將 age 設置為 23console.log(reactivePerson.age); // 獲取 age: 23

單個對象屬性和響應性

如果你不需要跟蹤對象中的所有字段,可以使用 Object.defineProperty 或一組 Object.defineProperties 來選擇特定的一個或幾個。vs928資訊網——每日最新資訊28at.com

const person = {  _originalName: 'Pavel', // 私有屬性}Object.defineProperty(person, 'name', {  get() {    console.log('獲取屬性 name')    return this._originalName  },  set(value) {    console.log(`將屬性 name 設置為值 ${value}`)    this._originalName = value  },})console.log(person.name) // '獲取屬性 name' 和 'Pavel'person.name = 'Sergei' // 將屬性 name 設置為值 Sergei

使用 MutationObserver 的響應式 HTML 屬性

在 DOM 中實現響應性的一種方法是使用 MutationObserver。其 API 允許我們觀察目標元素及其子元素的屬性變化和文本內容變化。vs928資訊網——每日最新資訊28at.com

function handleMutations(mutationsList, observer) {  mutationsList.forEach((mutation) => {    // 觀察到的元素的一個屬性發生了變化    if (mutation.type === 'attributes') {      console.log(`屬性 '${mutation.attributeName}' 更改為 '${mutation.target.getAttribute(mutation.attributeName)}'`);    }  });}const observer = new MutationObserver(handleMutations);const targetElement = document.querySelector('.element-to-observe');// 開始觀察目標元素observer.observe(targetElement, { attributes: true });

使用 IntersectionObserver 的響應式滾動

IntersectionObserver API 允許對目標元素與另一個元素或視口區域的交集做出反應。vs928資訊網——每日最新資訊28at.com

function handleIntersection(entries, observer) {  entries.forEach((entry) => {    // 目標元素在視口中    if (entry.isIntersecting) {      entry.target.classList.add('visible');    } else {      entry.target.classList.remove('visible');    }  });}const observer = new IntersectionObserver(handleIntersection);const targetElement = document.querySelector('.element-to-observe');// 開始觀察目標元素observer.observe(targetElement);

本文鏈接:http://m.www897cc.com/showinfo-26-91830-0.html八種現代 JavaScript 響應式模式

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: C#隊列(Queue)的基本使用,一文全掌握

下一篇: Spring中都應用了哪些設計模式呢?

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
麻豆成人综合网| 亚洲欧美一区二区三区在线| 激情成人中文字幕| 亚洲成人在线视频播放| 亚洲精品免费在线播放| 一本色道综合亚洲| 午夜一级久久| 欧美成人有码| 欧美亚洲成人精品| 国产一区二区三区日韩欧美| 91久久极品少妇xxxxⅹ软件| 一区二区三区视频在线播放| 欧美一区二区日韩| 欧美jizzhd精品欧美巨大免费| 欧美婷婷久久| 激情自拍一区| 亚洲视频自拍偷拍| 久久综合999| 国产精品久久久免费| 在线观看成人av| 亚洲视频网站在线观看| 久久琪琪电影院| 国产精品理论片| 91久久久久久久久| 先锋影音久久久| 欧美日韩国产影院| 黄页网站一区| 亚洲欧美激情视频| 欧美激情精品久久久久久免费印度| 国产精品视频网| 亚洲精品视频二区| 久久久久久999| 国产精品久久久久久久午夜片 | 国内在线观看一区二区三区| 99在线视频精品| 久久久亚洲高清| 国产精品久久久久久久久婷婷 | 国产一区二区精品丝袜| 99精品国产一区二区青青牛奶| 久久精品国产第一区二区三区最新章节 | 欧美激情按摩在线| 国产专区综合网| 亚洲特黄一级片| 欧美国产三级| 一区二区亚洲精品| 香蕉久久夜色精品国产| 欧美日韩国产首页| 1024国产精品| 久久精品国产77777蜜臀| 国产精品二区二区三区| 亚洲精品欧美| 你懂的亚洲视频| 国内精品久久久| 新片速递亚洲合集欧美合集| 国产精品福利网| 在线综合亚洲欧美在线视频| 欧美风情在线| 在线观看日韩专区| 久久精品日韩欧美| 国产亚洲欧美aaaa| 欧美一二三视频| 国产精品白丝jk黑袜喷水| 亚洲精品综合在线| 欧美成人综合在线| 在线日韩av片| 久久一区亚洲| 黄色成人小视频| 久久九九国产精品怡红院| 国产欧美精品在线| 亚洲影院免费| 国产精品久久久久久久午夜片| 在线中文字幕日韩| 欧美日精品一区视频| 一本到12不卡视频在线dvd| 欧美精品一区二区三区很污很色的 | 欧美视频在线观看免费网址| 亚洲美女视频在线观看| 欧美极品影院| 亚洲精品视频免费在线观看| 欧美国产日韩一区二区在线观看 | 国产亚洲精品激情久久| 欧美中文在线免费| 国产欧美日韩91| 久久精品毛片| 一区福利视频| 免费看亚洲片| 亚洲精品系列| 欧美肉体xxxx裸体137大胆| 一本色道久久综合| 国产精品播放| 欧美一级理论片| 国内自拍一区| 猫咪成人在线观看| 最新成人av网站| 欧美日韩成人一区二区| 一区二区三区**美女毛片 | 影音先锋久久精品| 欧美77777| 一区二区三区四区蜜桃| 国产精品久久久久久妇女6080| 亚洲欧美国产精品va在线观看| 国产欧美日韩麻豆91| 久久久久青草大香线综合精品| 激情一区二区三区| 欧美国产先锋| 亚洲一区二区三区777| 国产日韩视频一区二区三区| 久久综合色综合88| 亚洲精品中文在线| 国产精品国产福利国产秒拍| 欧美伊人影院| 亚洲高清免费在线| 欧美日韩一二三区| 欧美一级理论性理论a| 在线日韩av| 欧美午夜精品久久久久久超碰| 午夜视频久久久久久| 在线精品视频一区二区| 欧美日韩成人精品| 午夜日韩电影| 亚洲黄色片网站| 国产精品美女主播| 久久综合五月| 亚洲一区二区3| 黄页网站一区| 欧美无砖砖区免费| 久久久91精品国产一区二区精品| 亚洲欧洲日本国产| 国产精品一区二区三区观看| 免费一区二区三区| 亚洲欧美视频| 亚洲国产天堂久久国产91| 欧美视频中文一区二区三区在线观看 | 欧美—级高清免费播放| 午夜天堂精品久久久久| 亚洲第一精品夜夜躁人人爽 | 亚洲乱码视频| 国产日韩欧美精品综合| 欧美国产乱视频| 欧美一区网站| 99视频在线观看一区三区| 韩国成人理伦片免费播放| 欧美精品一区二区三区蜜桃| 欧美一区二区三区另类 | 亚洲三级影院| 国产主播在线一区| 欧美视频精品在线| 免费在线成人av| 欧美一区国产二区| 亚洲天堂第二页| 最新国产精品拍自在线播放| 国产色综合天天综合网| 欧美日韩亚洲综合在线| 免费成人黄色片| 欧美一区视频在线| 在线亚洲伦理| 亚洲片在线观看| 激情久久综艺| 国产女主播一区| 欧美视频二区36p| 欧美成人综合在线| 久久九九久精品国产免费直播 | 久久亚洲色图| 午夜一区二区三区不卡视频| 日韩一区二区福利| 伊人久久久大香线蕉综合直播| 国产精品美女久久久| 欧美日韩精品国产| 欧美1区免费| 久久久午夜视频| 欧美一级电影久久| 亚洲一区二区三区涩| 亚洲精品视频在线播放| 精品av久久久久电影| 国产精品一区视频| 欧美日韩视频一区二区| 欧美黑人一区二区三区| 狂野欧美激情性xxxx| 久久国产精品99国产精| 亚洲欧美网站| 亚洲一区二区三区在线看 | 久久综合精品国产一区二区三区| 欧美一级大片在线观看| 亚洲影院色在线观看免费| 一区二区三区av| 99精品国产一区二区青青牛奶| 亚洲日本va午夜在线影院| 亚洲二区三区四区| 一区二区三区在线观看国产| 国产综合久久| 国内精品视频在线播放| 国产一区二区久久久| 国产一区二区三区四区三区四| 国产欧美一级| 国产视频久久久久久久| 国产欧美另类| 国产日韩精品一区| 国产欧美日韩精品a在线观看| 国产精品视区| 国产九色精品成人porny| 国产毛片一区| 国内成+人亚洲+欧美+综合在线| 国产在线高清精品| 国外成人网址|