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

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

研究基于 Vue版本 【2.5.17】

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

在这里插入图片描述

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

|

不过据我了解,连张鑫旭大佬都喜欢使用 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 里面去打断点啦,额..... 虽然现在你还不知道打什么断点,不过不用怕!后面每次讲一块内容,你就可以去自己尝试啦

在这里插入图片描述

结尾

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

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

希望本文会对你有帮助

好的,谢幕了

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券