色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

Vue 如何追蹤數據變化

瀏覽:8日期:2022-09-30 17:55:16
背景

工作中時不時就會遇到這種情況:頁面上顯示的數據不對,需要前端同事進行定位。

在一個使用 Vue 搭建的 SPA 應用上,頁面最終展示的數據,從初始化,到最后的展示,過程可能很簡單,也可能很復雜。遇到復雜的數據流,沒有合適的方法,排查起來會很頭疼。

如果能夠看到數據發生變化時的調用棧,就可以知道在錯誤的數據生成前,發生了什么,是哪一步的錯誤,導致了最終的錯誤。順著調用棧給出的線索找下去,就能夠快速定位到問題。

例子

<template> <div> <!-- 預期輸出:hello,world --> <!-- 實際輸出:hello,woold --> {{ msg }} <button @click='f1'>change msg</button> </div></template><script>export default { data() { return { msg: ’hello,’, } }, methods: { f1() { this.msg += ’w’ this.f2(); }, f2() { this.msg += ’oo’; this.f3(); }, f3() { this.msg += ’ld’ } }};</script>誤區 - 在 Watch 里打斷點查看調用棧

Vue 如何追蹤數據變化

我們可以在頁面右邊的 Call Stack 看到 f1 和 msg 的回調,但是看不到 f2 和 f3。也就是說 f2, f3 丟失了,但實際上正是 f2 導致數據發生了錯誤。

為什么 f2,f3 的調用信息會丟失?

因為 f1, f2, f3 都修改了 msg,在同一個微任務里觸發了 msg 的 Watcher,因為 f1 最先觸發,所以f2,f3 的觸發無效。最終 Watcher 回調運行的時候,只記得是 f1 觸發它的,所以此時的 Call Stack 只能看到 f1 的信息。

正確的做法

進入到 node_modulesvuedistvue.runtime.esm.js,在 defineReactive 函數的 set 方法里添加斷點,這里的 key 就是要監聽的變量的名字。

Vue 如何追蹤數據變化

在這里,就能夠看到 msg 發生變化的完整過程,快速定位到是 f2 導致的問題。

總結

通過查看調用棧的方式,不需要對項目有多熟悉,就能夠快速定位到數據發生錯誤的地方。相比于用 console.log 或者花很多時間去理清代碼邏輯,數據流的方式,可以減少很多的工作量。

以上就是Vue 如何追蹤數據變化的詳細內容,更多關于Vue 追蹤數據變化的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: www.久久视频| 暖暖日本在线播放 | 亚洲国产精品激情在线观看 | 成人欧美一区在线视频在线观看 | 一级片视频在线 | 欧美高清一级 | www.99精品视频在线播放 | 一级片免 | 国产精品18久久久久久久久久 | 国产高清精品一级毛片 | 免费一级a毛片免费观看欧美大片 | 欧美国产在线视频 | 久久精品一区二区三区四区 | 中国一级毛片免费观看 | 国内视频自拍 | 亚洲欧美日韩久久精品第一区 | 日韩中文字幕精品一区在线 | 91看片淫黄大片.在线天堂 | 狠狠色狠狠综合久久 | 在线亚洲日产一区二区 | 亚洲欧美成人网 | 国产在线精品一区二区三区不卡 | 欧美一区不卡二区不卡三区 | 久久综合精品国产一区二区三区无 | 香蕉521av网站永久地址 | 美国成人免费视频 | 国产欧美日韩在线视频 | 亚洲精品高清在线 | 欧美日韩一区二区三 | 泰国情欲片寂寞的寡妇在线观看 | 欧美成人精品高清在线播放 | 美国一级毛片在线 | 99九九99九九九视频精品 | 97视频久久| 亚洲国产网址 | 女人张开腿让男人捅爽 | 人妖欧美一区二区三区四区 | 99久久www免费 | 国产精品18久久久久网站 | 国产毛片基地 | 黄毛片一级毛片 |