国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

Vue 如何追蹤數據變化

瀏覽:5日期: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
相關文章:
主站蜘蛛池模板: 一区二区三区在线播放视频 | 67194欧美成l人在线观看免费 | 荡女妇边被c边呻吟久久 | 免费看三级毛片 | 亚洲精品国产一区二区 | 国产精品自拍亚洲 | 成人精品在线观看 | 精品一区二区三区五区六区 | 亚洲一级毛片视频 | 九草在线观看 | 男女男精品视频网站 | 欧美人成一本免费观看视频 | 欧美日本一区 | 理论视频在线观看 | 国产成人香蕉久久久久 | 手机看片手机在线看片 | 国产精品三级在线播放 | 亚洲欧美一区二区三区四区 | 久久精品国产三级不卡 | 91精品久久久 | 精品午夜久久网成年网 | 一级片aaa| 欧美在线一二三区 | 亚洲免费在线观看 | 国产亚洲精品久久久久久午夜 | 欧美高清视频在线 | 深夜爽爽福利gif在线观看 | 国产欧美一级片 | 亚洲免费精品视频 | 欧美一区二区三区不卡免费观看 | 免费91最新地址永久入口 | 亚洲欧美精品成人久久91 | 国产综合在线播放 | 亚洲精品一区二区手机在线 | 最新国产美女一区二区三区 | 久久亚洲精品成人 | 丝袜美腿精品一区二区三 | 品色堂永久免费 | 99精品国产一区二区三区 | 久草在现 | xxxwww欧美性|