vue3 开启本地调试

前言

最近在进行 vue3 源码的学习,将掘金作为学习笔记,记录一下学习的过程以及自己的理解,从0开始搭建 mini-vue。

vue 如何开启本地调试

下载 vue 源码

github 官网进行下载,可以通过 git 下载,也可以直接通过 download zip 进行下载,内容是一样的

创建测试html

下载完vue项目之后,我们现在本地进行打包,通过:

shelll 复制代码
pnpm i

安装依赖,然后通过

shell 复制代码
npm run build

进行打包,之后我们就能够在项目的 /packages/vue/dist 中找到打包文件,然后我们通过创建一个简单的html文件来引入这个打包文件,并且尝试着使用 reactive。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
   <meta charset="UTF-8">
   <meta http-equiv="X-UA-Compatible" content="IE=edge">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>Document</title>
   <script src="../../dist/vue.global.js"></script>
</head>

<body>
   <div id="app"></div>
</body>
<script>
   const { reactive } = Vue

   const obj = reactive({
       name: '张三'
   })
</script>
</html>

但是因为我们引入的是vue的打包文件,所以这里哪怕通过断点也看不到任何源码中的内容,所以我们要来开启 SourceMap 方便我们之后的断点调试。

开启 SourceMap

在 vue 的打包命令中,我们会发现,其实打包就是执行 script 底下的 build 文件,那么我们在 build 文件当中能够找到这一段代码

js 复制代码
await execa(
    'rollup',
    [
      '-c',
      '--environment',
      [
        `COMMIT:${commit}`,
        `NODE_ENV:${env}`,
        `TARGET:${target}`,
        formats ? `FORMATS:${formats}` : ``,
        buildTypes ? `TYPES:true` : ``,
        prodOnly ? `PROD_ONLY:true` : ``,
        sourceMap ? `SOURCE_MAP:true` : ``
      ]
        .filter(Boolean)
        .join(',')
    ],
    { stdio: 'inherit' }
  )

根据 sourceMap 我们能够找到设置这个变量的位置:

js 复制代码
const args = require('minimist')(process.argv.slice(2))
console.log("🚀 ~ file: build.js:26 ~ args:", args)
...
const sourceMap = args.sourcemap || args.s

minimist 是一个 解析参数选项 的第三方库,用于解析命令行命令后面携带的额外参数

然后我们尝试着在打包命令中增加参数,并且重新打包

shell 复制代码
node scripts/build.js -s
🚀 ~ file: build.js:26 ~ args: { _: [], s: true }

这时候我们就可以看见控制台输出的参数,其中 s 变成了 true ,那么我们也就找到了开启 SoucreMap 的位置,然后就可以通过修改 packjson 中的打包命令,来开启 SoucreMap

shell 复制代码
 "build": "node scripts/build.js -s",

然后我们重新打包,回到最开始的测试文件当中

找到 reactive 文件,在其中我们就能够找到 reactive 这个函数,在其中打一个断点,然后刷新浏览器。

这样我们就成功开启了源码中的断点

总结

本文作为 vue 源码学习的第一篇,主要是记录一下 vue3 源码开启调试的方法。

相关推荐
Byron070717 分钟前
从 0 到 1 搭建 Vue 前端工程化体系:提效、提质、降本实战落地
前端·javascript·vue.js
哆啦code梦20 分钟前
前端存储三剑客:localStorage、sessionStorage与Cookie解析
前端·前端存储
zhengfei61123 分钟前
【AI平台】- 基于大模型的知识库与知识图谱智能体开发平台
vue.js·语言模型·langchain·知识图谱·多分类
徐小夕@趣谈前端33 分钟前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
Data_Journal1 小时前
如何使用 Python 解析 JSON 数据
大数据·开发语言·前端·数据库·人工智能·php
德育处主任Pro1 小时前
纯前端网格路径规划:PathFinding.js的使用方法
开发语言·前端·javascript
墨笔.丹青1 小时前
基于QtQuick开发界面设计出简易的HarmonyUI界面----下
开发语言·前端·javascript
董世昌411 小时前
深度解析浅拷贝与深拷贝:底层逻辑、实现方式及实战避坑
前端·javascript·vue.js
扶苏10021 小时前
vue使用event.dataTransfer实现A容器数据拖拽复制到到B容器
前端·vue.js·chrome
David凉宸1 小时前
Vue 3 项目的性能优化策略:从原理到实践
前端·vue.js·性能优化