Vue原理看Vue源码不会调试不行啊

44次阅读

共计 2514 个字符,预计需要花费 7 分钟才能阅读完成。

写文章不容易,点个赞呗兄弟
专注 Vue 源码分享,文章分为白话版和 源码版,白话版助于理解工作原理,源码版助于了解内部详情,让我们一起学习吧
研究基于 Vue 版本 【2.5.17】

如果你觉得排版难看,请点击 下面链接 或者 拉到 下面 关注公众号 也可以吧

【Vue 原理】学会调试 Vue 源码

调试是程序猿必备的技能,如果你不会调试,你的下场就是 ………

嗯,一样可以拿高工资 …………

不过据我了解,连张鑫旭大佬都喜欢使用 console.log 调试,但是你以为别人不用,你就以为别人不会吗,你真的太天真了 ….

下面的评论也是 … 看来同是天涯沦落人

我在项目中也是使用 console.log 调试啊,但是阅读源码不一样啊,你试试一直用 console.log 调试,搞不死你


好了,进入正题 ….

进入 VSCode 调试界面

是是是,让我们把眼睛移动到 VSCODE 左边活动栏 这边

1、有个小虫 ,点击进入调试界面

2、或者按快捷键,ctrl+shift+D

错!其实第一步你应该打开 VSCode


创建调试配置文件

点击这个小设置按钮

之后,会弹窗,让你选择调试的类型,我们选择 Chrome,骚年

Duang 的一声,你会发现自动生成了一个配置文件

然后这一步你就成功了呗 …. 到下一步了


配置调试配置文件

配置文件有很多选项,我只给出最简单的可以使用的版本

{
"version": "0.2.0",
"configurations": [
{
"type": "chrome",
"request": "launch",
"name": "调试 Vue 的调用走向",
"file": "${workspaceRoot}/index.html",
}
]
}

解释一下 (• ̀ω•́)✧

type

是你调试类型,你调试的是网页,还是调试 node。

现在我们调试网页,所以选择 Chrome

name

调试名称,随你起名字,起 个 xxxxxx

file

本地文件路径,调试 本地 文件(workspaceRoot 是项目根目录,以此来确定你的 html 调试页面 相对路径)


开始调试

打断点

在 文件的 序号一栏 的左边,可以标记红色断点

然后可以在序号栏 左边,看到你打的所有断点

启动调试

点击下面的按钮,立即启动调试,等个几秒钟??

启动成功

然后你发现 谷歌浏览器被自动启动了,然后你就成功了兄弟

看得到 浏览器 的 url 是你的 硬盘绝对路径,也就是你在配置文件里面配置的

TIP:如果你启动调试期间出现什么问题,不要怕,度娘 或者 谷哥,资料很多,我也碰到很多问题,很正常

(~~▽~)~


调试工具栏

启动调试成功之后,你可以看到 这个工具栏的出现

我们来一个个看 每个按钮都是什么作用


继续,跳断点,从一个断点 跳到 另一个断点

单步跳过

跳过函数执行,就是 不进入函数内部,直接执行完函数,跳到函数下一个语句

TIP:但是如果你在这个函数的内部 打了断点,点击【单步跳过】你还是会进入函数内部,然后跳到函数内部最近那个断点那行

ヾ(●´∀`●)

单步跳出

跳出 单签函数体,如果当前调试已经进入了某个函数,那么立即执行完当前函数,并跳出这个函数

TIP:但是如果你在这个函数的内部 打了断点,你可能跳不出去,而是跳到这个函数 内部最近的一个断点

重启,重新启动调试,从头开始

停止,关闭调试


**

举栗子 (´・ᴗ・`)

**

准备好文件

index.html,越短越好

<script src="./index.js"></script>

index.js

function fn1(name){
var result = name+"fn1 处理过"
fn2(result)
}
function fn2(arg){return arg +"fn2 处理过"}
fn1("hoho")

01 新建调试文件 launch.json

{
"version": "0.2.0",
"configurations": [
{
"type": "chrome",
"request": "launch",
"name": "调试 Demo",
"file": "${workspaceRoot}/index.html",
}
]
}

02 打断点

03 启动调试,来到第一个断点

04 开始调试

先讲按钮使用流程

现在执行到 fn1 函数这一行,但是 fn1 还没执行

此时点击

执行 fn1,进入 fn1 函数内部

进入 fn1 之后

一直点击 ,直到执行到 fn2 语句

像下面这样,有条黄线,就表示执行到哪条语句

1、点击 ,会 立即执行完 fn2,不进入 fn2

2、点击

,会 进入 fn2

如果进入了 fn2 之后

点击

,会立即执行完 fn2 函数,跳出 fn2 函数内部

现在,我们

三个按钮都使用过了,还剩

我们在 fn2 处打多一个一个断点,然后重启

你能看到 现在又是停到了 第一个断点处

此时,你的小手一按

,于是你便跳到了刚打的第二个断点

观察变量值

1、可以把鼠标移动到 某个变量上,会显示一个弹窗,弹窗内容是 变量的值

2、或者可以查看 左栏 调试栏的 变量

观察函数调用流程

同样是查看左边的 调试栏,中的调用堆栈,可以看到 函数调用的顺序

明显可以看到 先调用 fn1,在调用 fn2

好的,如果你 有跟着做的,相信你已经入门了兄弟,是不是十分钟从入门到精通??


调试 Vue 准备

index.html

引用 vue 文件、引用 vue.test.js 文件

<!DOCTYPE html>
<html lang="en"><head></head><body>
<div class="a" >
<testb></testb>
</div>
<script src="./vue.js"></script>
<script src="./vue.test.js"></script>
</body>
</html>

vue.js

去官网下载生产版本即可

vue.test.js

作用是调用 vue,创建一个简单的应用,现在给一个简单的模板

new Vue({
el:".a",
data(){
return {name:1}
},
methods:{getName(){this.name="修改 ---- 我是父组件 a"},
},
})

现在,你可以尽情去 vue 里面去打断点啦,额 ….. 虽然现在你还不知道打什么断点,不过不用怕!后面每次讲一块内容,你就可以去自己尝试啦


结尾

好的,本次讲解完毕,调试就是这么简单,真的没有什么难的,

最后有什么不对的地方,感谢指出

希望本文会对你有帮助

好的,谢幕了

正文完
 0