前端UI邏輯復雜可以用什么設計模式

中介者模式

當UI組件間存在復雜交互或多個組件需共享狀態時,中介者模式能集中管理事件分發和狀態更新,減少組件間的直接依賴,提升解耦性。

vue實現中介者模式

在Vue中實現中介者模式,你可以通過創建一個全局的事件中心(Event Bus)或者使用一個專門的庫如mitt、tiny-emitter等來實現。中介者模式主要用于減少組件之間的直接通信,通過一個中介者對象來處理不同組件之間的交互。下面,我將介紹如何在Vue中使用這兩種方式來實現中介者模式。
方法1:使用Vue的Event Bus
步驟1:創建Event Bus

首先,創建一個事件總線(Event Bus)文件,例如event-bus.js:

// event-bus.js
import Vue from 'vue';
export const EventBus = new Vue();

步驟2:在組件中使用Event Bus
然后在需要通信的組件中引入并使用這個Event Bus:

// ComponentA.vue
<template><div><button @click="sendData">Send Data</button></div>
</template><script>
import { EventBus } from './event-bus';export default {methods: {sendData() {EventBus.$emit('send-data', 'Hello from Component A');}}
}
</script>
// ComponentB.vue
<template><div>Received: {{ message }}</div>
</template><script>
import { EventBus } from './event-bus';export default {data() {return {message: ''};},created() {EventBus.$on('send-data', (data) => {this.message = data;});}
}
</script>

Vue各種屬性控制不同的組件應該怎樣設計

觀察者模式

適用于需要組件間狀態監聽與響應的場景(如動態加載頁面內容、用戶行為觸發界面變化),通過訂閱-發布機制實現無侵入式更新。

策略模式

當UI邏輯涉及多種算法或規則(如不同交互反饋機制),可通過策略模式動態切換實現方式,避免硬編碼不同路徑的代碼分支。

迭代器模式

處理復雜數據結構(如嵌套列表、樹形菜單)時,通過迭代器逐步構建UI組件,降低遞歸調用復雜度,保持代碼結構清晰。

模板方法模式

針對重復性UI操作(如彈窗、提示框),通過模板方法定義通用流程框架,僅修改特定參數即可適應不同場景,減少重復代碼。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/88362.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/88362.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/88362.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

WIFI協議全解析05:WiFi的安全機制:IoT設備如何實現安全連接?

&#x1f510; WiFi的安全機制&#xff1a;IoT設備如何實現安全連接&#xff1f;“我的設備明明連上WiFi了&#xff0c;為什么還是能被‘蹭網’&#xff1f;” “WPA3 是什么&#xff1f;ESP32 支持嗎&#xff1f;” “我做了MQTT加密就算安全了嗎&#xff1f;”IoT設備連接WiF…

HTTP 請求體類型詳解:選擇最適合的數據提交格式

HTTP 請求體類型詳解&#xff1a;選擇最適合的數據提交格式 &#x1f680; 本文全面解析 HTTP 請求中不同 Content-Type 的適用場景、數據結構與優劣勢&#xff0c;幫助開發者高效選擇數據傳輸方案。 &#x1f4cc; 目錄 核心請求體類型對比詳細類型解析最佳實踐指南總結 &am…

C語言 | 函數核心機制深度解構:從底層架構到工程化實踐

個人主頁-愛因斯晨 文章專欄-C語言 引言 最近偷懶了&#xff0c;迷上了三國和李賀。給大家分享一下最喜歡的一句詩&#xff1a;吾不識青天高黃地厚&#xff0c;唯見月寒日暖來煎人壽。我還不是很理解27歲的李賀&#xff0c;如何寫出如此絕筆。 正文開始&#xff0c;今天我們…

uniapp真機調試“沒有檢測到設備,請插入設備或啟動模擬器后點擊刷新再試”

當真機調試&#xff0c;運行到安卓 APP基座 時&#xff0c;有時會檢測不到設備&#xff0c;顯示下面的問題&#xff1a;此時&#xff0c;可以通過下面的幾種方法進行排查&#xff1a;1.在手機中找到“開發者選項”選項&#xff08;可在設置中搜索&#xff0c;如搜索不到&#x…

使用langchain連接llama.cpp部署的本地deepseek大模型開發簡單的LLM應用

langchain是一個基于python實現的開源LLM開發框架&#xff0c;llama.cpp是一個基于C框架可以在本地部署大模型并開放服務端接口開放給外部應用使用。 本文結合langchain和llama.cpp&#xff0c;在本地部署輕量級的deepseek大模型&#xff0c;并構建一個簡單的鏈式LLM應用&…

Serverless 數據庫來了?無服務器數據庫 vs 傳統數據庫有何不同?

隨著云計算技術的迅猛發展&#xff0c;無服務器&#xff08;Serverless&#xff09;架構逐漸成為一種主流趨勢。其中&#xff0c;Serverless 數據庫作為云原生應用的重要組成部分&#xff0c;為開發者提供了前所未有的靈活性和成本效益。相比傳統的數據庫管理方式&#xff0c;S…

【讀書筆記】如何畫好架構圖:架構思維的三大底層邏輯

【讀書筆記】如何畫好架構圖&#xff1a;架構思維的三大底層邏輯 架構圖并非技術人的“畫功比拼”&#xff0c;而是一個團隊、一個系統、一次項目從混沌走向清晰的關鍵抓手。它是系統的視覺語言&#xff0c;是讓技術人員、產品經理、運營甚至老板都能站在統一上下文下討論的“…

Maven 編譯過程中發生了 Java Heap Space 內存溢出(OutOfMemoryError)

這個是我最近遇到的&#xff0c;因為本人最近換了電腦&#xff0c;這個電腦的前任是配置好了環境&#xff0c;但是當我用這個環境去做另外一個項目的時候&#xff0c;在maven構建war和jar包的時候&#xff0c;報了這個內存溢出mvn clean install 就給我報錯了[ERROR] Failed to…

C++ 模板參數展開

C 模板參數展開一、獲取可變參數大小二、通過模版循環繼承的方式來展開可變參數三、改用Using去實現循環繼承一、獲取可變參數大小 背景&#xff1a; FLen<int, char, long> Len; 我想要獲取模板參數類型的總大小 template<typename T,typename ...ParamTypes> c…

零基礎入門物聯網-遠程門禁開關:云平臺創建

一、 onenet云平臺注冊創建 遠程開關的信息傳輸依賴云平臺&#xff0c;本教程以 OneNET - 中國移動物聯網開放平臺為例進行操作&#xff0c;具體步驟如下&#xff1a; 1、平臺賬號創建 點擊 OneNET - 中國移動物聯網開放平臺進入官網 點擊頁面中的 “登錄” 按鈕&#xff0c;…

html頁面,當鼠標移開A字標就隱藏顏色框

html頁面代碼&#xff1a;<!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><title>顏色選擇器</title><style>body {font-family: "Microsoft YaHei", sans-serif;padding: 20px;}.c…

保姆級搭建harbor私有倉庫與docker-ce教程與使用教程

搭建harbor倉庫[rootharbor ~]# vim cat /etc/host192.168.121.12 harbor[rootharbor ~]# vim /etc/hostnameharbor導入 harbor 項目鏡像[rootharbor ~]# tar -zxf harbor-v2.9.2.tgz -C /usr/local/[rootharbor ~]# cd /usr/local/harbor[rootharbor harbor]# docker load -i…

【Linux】Rocky Linux 安裝 Docker 與 Docker-Compose

Docker 安裝步驟 1. 安裝必要的軟件包 sudo yum install -y yum-utils sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo2. 安裝Docker sudo yum install docker-ce docker-ce-cli containerd.io如果出現 SSL 證書錯誤&#xf…

揭示獨特模式:Elasticsearch 中 significant terms 聚合指南

作者&#xff1a;來自 Elastic Alexander Dvila 了解如何使用 significant terms 聚合來發現你數據中的洞察。 更多閱讀&#xff1a;Elasticsearch&#xff1a;significant terms aggregation Elasticsearch 擁有大量新功能&#xff0c;可以幫助你為你的使用場景構建最佳搜索解…

pandas.DataFrame中axis參數

明確axis0與axis1的區別和聯系&#xff0c; 假設有一個 DataFrame&#xff1a;indexAB012134axis0&#xff08;沿行方向&#xff09;&#xff1a; 操作會垂直向下進行&#xff0c;對每一列單獨處理。 例如&#xff1a;df.sum(axis0) 會對列 A 和列 B 分別求和&#xff0c;結果是…

深度學習 最簡單的神經網絡 線性回歸網絡

用最簡單的線性模型講清 神經網絡 訓練全流程,讓你 5 分鐘看懂AI 是怎么學會預測的 ?? 1 真實神經元結構 ?? 真實神經元包括: 樹突 接收其他神經元傳來的電信號(輸入)。 細胞核 負責整合輸入信號并產生動作電位。 軸突 傳導動作電位到下一個神經元。 突觸 釋放神經遞質…

k8s Mutating Admission Webhook 實現超賣

目錄 1.什么是 Mutating Admission Webhook&#xff1f; 2.如何用 Mutating Admission Webhook 實現超賣&#xff1f; 3.實現超賣 3.1 理解目標 3.2 前置準備 3.3 開發 Mutating Webhook 3.4 配置 Webhook Server TLS 認證 3.5 注冊 MutatingWebhookConfiguration 3.6…

為 Go-llm-cpp 接入 Web API 接口,創建 Chatbot 聊天機器人

接續上一篇&#xff0c;用 Go 打造本地 LLM 聊天機器人&#xff1a;整合 llm-go 與 go-llama.cpp&#xff0c;此篇開始建構前端與 API 接口 執行環境需求 ? ? Go 1.20 ? ? C toolchain&#xff08;macOS: Xcode Command Line Tools / Linux: g&#xff09; ? ? GGUF 格式…

Docker筆記-Docker Compose

Docker筆記-Docker Compose Compose 是用于定義和運行多容器 Docker 應用程序的工具&#xff0c;通過 Compose 您可以使用 YML 文件來配置應用 程序需要的所有服務。然后&#xff0c;使用一個命令&#xff0c;就可以從 YML 文件配置中創建并啟動所有服務。 Compose 使用的三個步…

n1 armbian 安裝桌面環境并啟用xrdp遠程登錄

armbian-config armbian-software201frpcrootarmbian:~# armbian-software [ STEPS ] Start selecting software [ Current system: ubuntu/noble ]... ──────────────────────────────────────────────────────────…