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

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

關于vue中如何監聽數組變化

瀏覽:8日期:2022-09-30 13:00:50
前言

前段時間學習了關于vue中響應式數據的原理,(并作了學習筆記vue響應式原理),其實是通過Object.defineProperty控制getter和setter,并利用觀察者模式完成的響應式設計。那么數組有一系列的操作方法,這些方法并不會觸發數組的getter和setter方法。那么vue中針對數組的響應式設計是如何實現的呢...那么我們一起去學習下吧~

源碼部分

https://github.com/vuejs/vue/blob/dev/src/core/observer/array.js

從哪開始第一步學習呢

Emmmm...我覺得要先把Vue中的數據響應式原理弄清楚,這樣對于理解vue中是如何檢測數組的變化才比較好,所以,可以去網上找下文章然后配合源碼進行閱讀,相信你一定會理解的。推薦下我之前看的一篇博客,還有我看過后自己寫的學習記錄吧,哈哈。

vue響應式原理

vue的雙向綁定原理和實現

好的,先看看這個吧。哈哈!

從圖開始

咱們先看下下面的圖,先了解下vue中實現的思路,這樣接下來再看源碼的實現,會一清二楚,明明白白。

關于vue中如何監聽數組變化

看到這個圖然后思考一下,是不是大致了解了~

首先判斷瀏覽器是否支持__proto__指針

重寫數組的這7個方法,然后根據是否支持__proto__,將改寫后的數組指向數組的prototype。

是不是很簡單!!!

看看源碼吧

了解了實現原理,那么我們再看看源碼吧,看下源碼主要是更深入的了解作者是如何實現的,也可以看下優秀的代碼編碼方式,加以學習。

關于一些解釋我就寫在下面的代碼塊中了哈!

//https://github.com/vuejs/vue/blob/dev/src/core/observer/array.js//def方法是基于Object.defineProperty封裝的一層方法,很簡單,我會在下面把代碼貼出來,免得大家去找了。import { def } from ’../util/index’ //保存下原生的數組原型對象const arrayProto = Array.prototype//進行原型連接,將arrayMethods的原型指向Array.prototypeexport const arrayMethods = Object.create(arrayProto)const methodsToPatch = [ ’push’, ’pop’, ’shift’, ’unshift’, ’splice’, ’sort’, ’reverse’]methodsToPatch.forEach(function (method) { // 緩存原生的方法 const original = arrayProto[method] def(arrayMethods, method, function mutator (...args) { var args = [], len = arguments.length; while (len--) args[len] = arguments[len]; const result = original.apply(this, args) // 原來的數組方法執行結果 const ob = this.__ob__ // 這個__ob__就是Observe的實例~~~~ let inserted switch (method) { case ’push’: case ’unshift’:inserted = argsbreak case ’splice’:inserted = args.slice(2)break } if (inserted) ob.observeArray(inserted) // 如果數組有變化,則重新調用observeArray // notify change ob.dep.notify() // return result })})

這個是關于Observe的代碼:

var Observer = function Observer(value) { this.value = value; this.dep = new Dep(); this.vmCount = 0; def(value, ’__ob__’, this); //這里會看到在每個對象數據上都會綁定一個Observe的實例,所以上面代碼中的this.__ob__就是這個 if (Array.isArray(value)) { // 這里判斷是否是數組類型的數據,如果是的話就走observeArray if (hasProto) {protoAugment(value, arrayMethods); } else {copyAugment(value, arrayMethods, arrayKeys); } this.observeArray(value); //這里就是處理數組類型的數據,如下 } else { this.walk(value); } };

如下是observeArray的實現:

Observer.prototype.observeArray = function observeArray(items) { for (var i = 0, l = items.length; i < l; i++) { observe(items[i]); // 這個observe方法如下 } };

在這里我們看下observe這個方法:

function observe(value, asRootData) { if (!isObject(value) || value instanceof VNode) { return } var ob; if (hasOwn(value, ’__ob__’) && value.__ob__ instanceof Observer) { ob = value.__ob__; } else if ( shouldObserve && !isServerRendering() && (Array.isArray(value) || isPlainObject(value)) && Object.isExtensible(value) && !value._isVue ) { ob = new Observer(value); } if (asRootData && ob) { ob.vmCount++; } return ob }

這個是關于def方法的實現,很簡單我就不說了哈:

function def (obj, key, val, enumerable) { Object.defineProperty(obj, key, { value: val, enumerable: !!enumerable, writable: true, configurable: true });}

以上就是關于vue中如何監聽數組變化的詳細內容,更多關于vue如何監聽數組的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 小程序开发公司-小程序制作-微信小程序开发-小程序定制-咏熠软件 | 股指期货-期货开户-交易手续费佣金加1分-保证金低-期货公司排名靠前-万利信息开户 | 高低温试验房-深圳高低温湿热箱-小型高低温冲击试验箱-爱佩试验设备 | 广州/东莞小字符喷码机-热转印打码机-喷码机厂家-广州瑞润科技 | 申江储气罐厂家,储气罐批发价格,储气罐规格-上海申江压力容器有限公司(厂) | 恒湿机_除湿加湿一体机_恒湿净化消毒一体机厂家-杭州英腾电器有限公司 | 无菌检查集菌仪,微生物限度仪器-苏州长留仪器百科 | 数控走心机-走心机价格-双主轴走心机-宝宇百科 | 网带通过式抛丸机,,网带式打砂机,吊钩式,抛丸机,中山抛丸机生产厂家,江门抛丸机,佛山吊钩式,东莞抛丸机,中山市泰达自动化设备有限公司 | 100_150_200_250_300_350_400公斤压力空气压缩机-舰艇航天配套厂家 | 迪威娱乐|迪威娱乐客服|18183620002 | 氢氧化钙设备_厂家-淄博工贸有限公司| 北京百度网站优化|北京网站建设公司-百谷网络科技 | 好杂志网-首页| 档案密集架,移动密集架,手摇式密集架,吉林档案密集架-厂家直销★价格公道★质量保证 | 工业rfid读写器_RFID工业读写器_工业rfid设备厂商-ANDEAWELL | 矿用履带式平板车|探水钻机|气动架柱式钻机|架柱式液压回转钻机|履带式钻机-启睿探水钻机厂家 | 杜康白酒加盟_杜康酒代理_杜康酒招商加盟官网_杜康酒厂加盟总代理—杜康酒神全国运营中心 | 衬四氟_衬氟储罐_四氟储罐-无锡市氟瑞特防腐科技有限公司 | 半自动预灌装机,卡式瓶灌装机,注射器灌装机,给药器灌装机,大输液灌装机,西林瓶灌装机-长沙一星制药机械有限公司 | 除甲醛公司-甲醛检测治理-杭州创绿家环保科技有限公司-室内空气净化十大品牌 | 高压直流电源_特种变压器_变压器铁芯-希恩变压器定制厂家 | OpenI 启智 新一代人工智能开源开放平台| 塑料检查井_双扣聚氯乙烯增强管_双壁波纹管-河南中盈塑料制品有限公司 | 深圳货架厂家_金丽声精品货架_广东金丽声展示设备有限公司官网 | 东莞猎头公司_深圳猎头公司_广州猎头公司-广东万诚猎头提供企业中高端人才招聘服务 | 衬塑管道_衬四氟管道厂家-淄博恒固化工设备有限公司 | 桥架-槽式电缆桥架-镀锌桥架-托盘式桥架 - 上海亮族电缆桥架制造有限公司 | 期货软件-专业期货分析软件下载-云智赢 | 土壤墒情监测站_土壤墒情监测仪_土壤墒情监测系统_管式土壤墒情站-山东风途物联网 | 哈尔滨京科脑康神经内科医院-哈尔滨治疗头痛医院-哈尔滨治疗癫痫康复医院 | 西安耀程造价培训机构_工程预算实训_广联达实作实操培训 | PC构件-PC预制构件-构件设计-建筑预制构件-PC构件厂-锦萧新材料科技(浙江)股份有限公司 | 3dmax渲染-效果图渲染-影视动画渲染-北京快渲科技有限公司 | 鲸鱼视觉 -数字展厅多媒体互动展示制作公司 | 造价工程师网,考试时间查询,报名入口信息-网站首页 | 济南保安公司加盟挂靠-亮剑国际安保服务集团总部-山东保安公司|济南保安培训学校 | PVC快速门-硬质快速门-洁净室快速门品牌厂家-苏州西朗门业 | 广西教师资格网-广西教师资格证考试网| 电磁铁_推拉电磁铁_机械手电磁吸盘电磁铁厂家-广州思德隆电子公司 | 哈尔滨治「失眠/抑郁/焦虑症/精神心理」专科医院排行榜-京科脑康免费咨询 一对一诊疗 |