Vue3源码设计解析

本篇文章主要是学习如何阅读和调试Vue3源码,作为五年前端练习生我只会用,真的好奇它到底是如何实现的,而且学习源码带给我们好处不止这些,不仅面试必考,在工作中还能提高我们代码质量,真的是一件非常值得做的事啊!

下载vue的源代码(版本:v 3.2.37)

首先大家点击这里可以打开vue3源代码的github仓库; 想要下载Vue源码有常用的三种方式:

1.直接点击code => Download ZIP进行下载,这样下载的代码不包含git提交记录;

2.复制HTTPS或SSH的url,通过clone命令下载;

php 复制代码
//HTTPS
git clone https://github.com/vuejs/core.git
scss 复制代码
//SSH
git clone git@github.com:vuejs/core.git

3.点击fork按钮,fork当前项目到你的仓库下,再在你的仓库中执行以上两种方式下载,就可以根据当前版本生成自己的代码仓库;

本篇文章分析的是v 3.2.37版本源码,所以建议大家也下载此版本; 可以用这个命令:

bash 复制代码
git clone -b v3.2.37 --depth=1 https://github.com/vuejs/core.git

-b 后面写上指定版本标签,比如是v3.2.37--depth 表示深度克隆,1表示只克隆最新的版本;

分析源码的代码结构

完成了源码克隆,我们就可以来分析源码结构了,用VScode工具打开克隆下来的文件夹;

让我们重点看下package文件夹下的目录,标注不用关注的文件不是很重要可以先忽略;

运行源代码及测试实例

当我们下载好了源代码,接下来我们看一下,如何在Vue代码中运行测试实例,并进行debugger;

运行源代码

Vue是采用pnpm作为包管理工具的,首先全局安装pnpm:

css 复制代码
npm i -g pnpm

安装好了可以用pnpm -v命令查看当前的版本;pnpm安装完成可以执行pnpm i安装依赖;

css 复制代码
pnpm i

然后执行build命令完成打包操作;

arduino 复制代码
npm run build

打包完成会在packages/vue/目录下生成一个dist文件夹;

运行测试实例

Vue的实例都放在packages/vue/examples路径下的文件夹内; 接着在packages/vue/examples/vue-mini/reactivity目录下新建一个reactivity.html文件,在此文件中编写相关的测试代码;

xml 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <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, effect } = Vue

    const obj = reactive({
      name: '樱桃小丸子'
    })

    effect(() => {
      // 当前的div的内容会变成樱桃小丸子
      document.querySelector('#app').innerText = obj.name
    })
    // 7秒钟之后obj的setter把name改成哆啦A梦
    setTimeout(() => {
      obj.name = '哆啦A梦'
    }, 7000)
  </script>
</html>

通过script标签导入刚才打包好的dist路径下的global.js,并创建一个div id="app";

接着我们需要启动一个服务来运行当前的html;

推荐给大家一个vscode插件,叫Live Server,使用它可以启动服务更加方便;

安装完成之后,点击右键选择下图红框中的选项; 此时,我们成功启动一个服务来运行当前的html文件;

这时说明我们的测试实例运行成功了✿✿ヽ(°▽°)ノ✿

相关推荐
品克缤14 分钟前
Element UI MessageBox 增加第三个按钮(DOM Hack 方案)
前端·javascript·vue.js
小沐°29 分钟前
vue-设置不同环境的打包和运行
前端·javascript·vue.js
Irene19911 小时前
Vue3 <Suspense> 使用指南与注意事项
vue.js·suspense
花哥码天下2 小时前
恢复网站console.log的脚本
前端·javascript·vue.js
北辰alk2 小时前
Vue 的 nextTick:破解异步更新的玄机
vue.js
北辰alk2 小时前
Vue 技巧揭秘:一个事件触发多个方法,你竟然还不知道?
vue.js
北辰alk2 小时前
Vue 中 computed 和 watch 的深度解析:别再用错了!
vue.js
weipt6 小时前
关于vue项目中cesium的地图显示问题
前端·javascript·vue.js·cesium·卫星影像·地形
懒大王、6 小时前
Vue3 + OpenSeadragon 实现 MRXS 病理切片图像预览
前端·javascript·vue.js·openseadragon·mrxs
zhengxianyi5156 小时前
ruoyi-vue-pro数据大屏优化——在yudao-module-report-app使用yudao-moudle-sso优化单点登录
vue.js·前后端分离·数据大屏·go-view·ruoyi-vue-pro优化