电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

詳解從vue的組件傳值著手觀察者模式

瀏覽:3日期:2022-09-29 08:30:51
目錄觀察者模式Vue傳值第一步,我們先在main.js中注冊一下bus第二步,我們開始發送消息第三步,在組件三中接收消息vue的機制觀察者模式存在的意義觀察者模式

首先,提到觀察者模式,這不禁讓我想到了MVVM,MVVM架構模式感覺用到了觀察者的思想。

我們還是按照慣例,了解一下什么是觀察者模式

觀察者模式,類似發布訂閱模式,完成這個動作首先最少得有兩個不同的對象,或者多個對象,他更像是一種一隊多的依賴關系,也就是一種對象的狀態發生改變,與其相關所有的對象的狀態都會發生改變;比如說朋友圈這個功能,一個人可能有上百個好友,當我發布一條朋友圈后,所有和我成為好友的人都會看見這個朋友圈,當另一個人點贊后,所有你的好友其他點贊的人也會收到通知,這很像觀察者,也就是我是發布者,我的好友是訂閱者。

Vue傳值

然后我們看一下什么是vue,vue的原理大家都知道,他是一種自底向上的一種深入響應式的雙向綁定模式,即MVVM,也就是說,vue關注model的變化,model的變化讓mvvm框架更新dom,從而產生視圖view變化。

舉一個項目中很常見的例子:

在寫vue項目中我們都用過父子組件傳值,但是兄弟組件傳值是怎么實現的,首先我們可以用vuex,這很常見,但是還有一種方法不知道你用過沒有,就是Bus,這個Bus只是一種命名而已,叫什么無所謂,你可以叫飛機大炮都可以,這不重要,我們主要看看他是怎么實現的:

第一步,我們先在main.js中注冊一下bus

Vue.prototype.$Bus = new Vue()

我們往vue的原型里注冊了一個全局變量$Bus,他的值是vue的實例,也就是說,到現在為止,$Bus里邊有了vue所有的屬性和方法,這下就好操作了

第二步,我們開始發送消息

這就很符合觀察者模式的發布訂閱模式

我們在組件1中寫如下代碼:

<template> <div><button @click='send'>發送</button> </div></template><script>export default { methods: {send () { this.$Bus.$emit('send',’接收的信息’)} }}</script>

點擊按鈕發送一條信息,這個按鈕也就是充當發布者,我們用到了vue的$emit這個api,那么訂閱者是什么呢?我不說你也應該想到了,對,就是他

第三步,在組件三中接收消息

<template> <div>{{message}} </div></template><script>export default { data () {return { message: ’’} }, mounted () {this.$Bus.$on(’send’, (msg) => { this.message = msg}) }}</script>

就是用$on這個屬性充當接收者

從上可以看出,vue很多地方用到了觀察者的思想,包括他的雙向綁定也是如此

vue的機制

詳解從vue的組件傳值著手觀察者模式

從上圖我們可以看出,vue是通過Object.defineProperty實現對數據的劫持,然后中間做了一個中轉,最后渲染到vue層。

我們可以肯定的是,vue.js借鑒了觀察者模式,但是我感覺還是有點區別的,觀察者模式跟注重的是事件驅動,比如我買房這個動作,第一次和銷售了解可能沒有合適的房源,然后銷售就會跟你說: ‘如果有合適的房源我們會第一時間通知你’,當有新房源的時候他會給你打電話通知你,這一系列的根源是買房這個事件,他驅動了整套流程。而vue我們都知道是數據驅動,也就是只有data里的值發生改變的話,Object.defineProperty才會對他劫持,從而去更新dom,觸發視圖的更新。

那么有沒有更符合觀察者模式特征的?

當然是node.js的events事件了。

首先我們看看events的工作流程:

var events = require(’events’);// 創建 eventEmitter 對象var eventEmitter = new events.EventEmitter();// 創建事件處理程序var connectHandler = function connected() { console.log(’連接成功。’); // 觸發 data_received 事件 eventEmitter.emit(’data_received’);}// 綁定 connection 事件處理程序eventEmitter.on(’connection’, connectHandler);// 使用匿名函數綁定 data_received 事件eventEmitter.on(’data_received’, function(){ console.log(’數據接收成功。’);});// 觸發 connection 事件 eventEmitter.emit(’connection’);console.log('程序執行完畢。');

輸出一下:

詳解從vue的組件傳值著手觀察者模式

這就完全符合觀察者的工作模式,由emit發布,由on接收。所以說,node.js提供了很好的監聽機制,還有他對整個事務的處理 。其支持了nodejs最特色的I/O模式,比如我們啟動http服務時會監聽其 connect / close,http.request時會監聽 data / end等。

還有沒有類似的案例呢?

當然,js有一個事件監聽者----addEventListener,也有點觀察者的意思,具體用法我就不說了,想必大家用的都很熟悉。

其實只要你認真想一想,還是有很多地方有觀察者的身影的,最簡單的就是一個點擊事件,是不是也有其意思,發布者是一個按鈕,而接收者可以是表單,彈層等任何東西。

觀察者模式存在的意義

首先我們說說他的優點:

1,觀察者模式需要在觀察者和被觀察者之間建立一個耦合,他需要一個更加抽象化將二者聯系在一起

2,觀察者模式支持廣播,也就是一對多的關系,這就讓我們很容易想到一個技術,就是socket,具體可以參考vue項目使用websocket技術

然鵝,他也是優缺點的:

1,創建訂閱者本身要消耗一定的時間和內存

2,當訂閱一個消息時,也許此消息并沒有發生,但這個訂閱者會始終存在內存中。

3,觀察者模式弱化了對象之間的聯系,這本是好事情,但如果過度使用,對象與對象之間的聯系也會被隱藏的很深,會導致項目的難以跟蹤維護和理解。

等會兒,還有一個模式叫發布訂閱模式,很多人都以為他就是觀察者模式(包括我),后來我上網查了一下,發現他們還是有區別的,我們可以說觀察者模式和發布訂閱模式很像,真的很像,但是本質還是有點區別的,最根本的就是調度中心不同。

舉個例子,觀察者模式更注重是目標和觀察者是抽象類,比如天氣預報,觀察者A負責監聽天氣的變化,而B想得知天氣的變化需要將自己注冊到A中,而天氣變化的時候A觸發天氣變化,調度B的接口更新變化。

而發布訂閱模式是如何完成這個動作的呢?A想要感知天氣變化,需要B這個調度中心,而B得到天氣變化需要依賴C的觸發,可能我解釋的不是很清楚,網上有兩個圖比較好

詳解從vue的組件傳值著手觀察者模式

詳解從vue的組件傳值著手觀察者模式

以上就是詳解從vue的組件傳值著手觀察者模式的詳細內容,更多關于從vue的組件傳值著手觀察者模式的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 蜗轮丝杆升降机-螺旋升降机-丝杠升降机厂家-润驰传动 | 北京自然绿环境科技发展有限公司专业生产【洗车机_加油站洗车机-全自动洗车机】 | 氢氧化钙设备_厂家-淄博工贸有限公司 | 玻璃钢格栅盖板|玻璃钢盖板|玻璃钢格栅板|树篦子-长沙川皖玻璃钢制品有限公司 | 科昊仪器超纯水机系统-可成气相液氮罐-美菱超低温冰箱-西安昊兴生物科技有限公司 | 航空障碍灯_高中低光强航空障碍灯_民航许可认证航空警示灯厂家-东莞市天翔航天科技有限公司 | SPC工作站-连杆综合检具-表盘气动量仪-内孔缺陷检测仪-杭州朗多检测仪器有限公司 | 【直乐】河北石家庄脊柱侧弯医院_治疗椎间盘突出哪家医院好_骨科脊柱外科专业医院_治疗抽动症/关节病骨伤权威医院|排行-直乐矫形中医医院 | 十二星座查询(性格特点分析、星座运势解读) - 玄米星座网 | 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | 净化板-洁净板-净化板价格-净化板生产厂家-山东鸿星新材料科技股份有限公司 | 生物风-销售载体,基因,质粒,ATCC细胞,ATCC菌株等,欢迎购买-百风生物 | 美名宝起名网-在线宝宝、公司、起名平台 | 耐酸碱泵-自吸耐酸碱泵型号「品牌厂家」立式耐酸碱泵价格-昆山国宝过滤机有限公司首页 | 锯边机,自动锯边机,双面涂胶机-建业顺达机械有限公司 | 南京PVC快速门厂家南京快速卷帘门_南京pvc快速门_世界500强企业国内供应商_南京美高门业 | 贵州科比特-防雷公司厂家提供贵州防雷工程,防雷检测,防雷接地,防雷设备价格,防雷产品报价服务-贵州防雷检测公司 | 耐高温风管_耐高温软管_食品级软管_吸尘管_钢丝软管_卫生级软管_塑料波纹管-东莞市鑫翔宇软管有限公司 | 泵阀展|阀门展|水泵展|流体机械展 -2025上海国际泵管阀展览会flowtech china | HDPE储罐_厂家-山东九州阿丽贝防腐设备 | 中矗模型-深圳中矗模型设计有限公司 | 北京浩云律师事务所-法律顾问_企业法务_律师顾问_公司顾问 | 工业车间焊接-整体|集中除尘设备-激光|等离子切割机配套除尘-粉尘烟尘净化治理厂家-山东美蓝环保科技有限公司 | nalgene洗瓶,nalgene量筒,nalgene窄口瓶,nalgene放水口大瓶,浙江省nalgene代理-杭州雷琪实验器材有限公司 | 齿式联轴器-弹性联轴器-联轴器厂家-江苏诺兴传动联轴器制造有限公司 | 礼堂椅厂家|佛山市艺典家具有限公司| 暖气片十大品牌厂家_铜铝复合暖气片厂家_暖气片什么牌子好_欣鑫达散热器 | 颗粒机,颗粒机组,木屑颗粒机-济南劲能机械有限公司 | 丁基胶边来料加工,医用活塞边角料加工,异戊二烯橡胶边来料加工-河北盛唐橡胶制品有限公司 | 艺术生文化课培训|艺术生文化课辅导冲刺-济南启迪学校 | 哈尔滨京科脑康神经内科医院-哈尔滨治疗头痛医院-哈尔滨治疗癫痫康复医院 | 东莞螺杆空压机_永磁变频空压机_节能空压机_空压机工厂批发_深圳螺杆空压机_广州螺杆空压机_东莞空压机_空压机批发_东莞空压机工厂批发_东莞市文颖设备科技有限公司 | 布袋式除尘器|木工除尘器|螺旋输送机|斗式提升机|刮板输送机|除尘器配件-泊头市德佳环保设备 | 知网论文检测系统入口_论文查重免费查重_中国知网论文查询_学术不端检测系统 | 网络推广公司_网络营销方案策划_企业网络推广外包平台-上海澜推网络 | LHH药品稳定性试验箱-BPS系列恒温恒湿箱-意大利超低温冰箱-上海一恒科学仪器有限公司 | NM-02立式吸污机_ZHCS-02软轴刷_二合一吸刷软轴刷-厦门地坤科技有限公司 | 丹佛斯变频器-Danfoss战略代理经销商-上海津信变频器有限公司 | 宝元数控系统|对刀仪厂家|东莞机器人控制系统|东莞安川伺服-【鑫天驰智能科技】 | 丝印油墨_水性油墨_环保油墨油漆厂家_37国际化工 |