vue2.7.16源码 - Vue项目入口和打包核心代码分析

打包命令

css 复制代码
scripts:{
     "build": "node scripts/build.js",
}

scripts/build.js

  • 实际运行的打包命令,通过rollup实现

    javascript 复制代码
      const rollup = require('rollup')
      // 读取配置代码,开始构建代码
      let builds = require('./config').getAllBuilds()
    
      build(builds)
    
      function build (builds) {
        let built = 0
        const total = builds.length
        const next = () => {
          buildEntry(builds[built]).then(() => {
            built++
            if (built < total) {
              next()
            }
          }).catch(logError)
        }
        next()
      }
    
      }
    
      function buildEntry (config) {
        const output = config.output
        const { file, banner } = output
        const isProd = /(min|prod).js$/.test(file)
        return rollup.rollup(config)
          .then(bundle => bundle.generate(output))
          .then(async ({ output: [{ code }] }) => {
            if (isProd) {
              const {code: minifiedCode} =  await terser.minify(code, {
                toplevel: true,
                compress: {
                  pure_funcs: ['makeMap'],
                },
                format: {
                  ascii_only: true,
                }
              });
              const minified = (banner ? banner + '\n' : '') + minifiedCode
              return write(file, minified, true)
            } else {
              return write(file, code)
            }
          })
      }

scripts/config.js

  • 配置打包输出和输入路径

scripts/alias.js

  • 指定vue目标文件,web和sfc等目标文件

    less 复制代码
      const path = require('path')
    
      const resolve = p => path.resolve(__dirname, '../', p)
    
      module.exports = {
        vue: resolve('src/platforms/web/entry-runtime-with-compiler'),
        compiler: resolve('src/compiler'),
        core: resolve('src/core'),
        shared: resolve('src/shared'),
        web: resolve('src/platforms/web'),
        server: resolve('packages/server-renderer/src'),
        sfc: resolve('packages/compiler-sfc/src')
      }

src/platforms/web/entry-runtime-with-compiler.ts

  • vue对外暴露的入口文件,核心vue构造函数

引用过程(渐进增强)

  • entry-runtime-with-compiler
    • vue暴露的最外层核心类
    • 插入composition Api
    • watcher构建
  • src/platforms/web/runtime-with-compiler.ts
    • 增加render构建执行,触发mounted
  • src/platforms/web/runtime/index.ts
    • 注入components和$mount
  • src/core/index.ts
    • 注入静态属性和预置生命周期
相关推荐
梦帮科技21 分钟前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
VT.馒头1 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
css趣多多1 小时前
一个UI内置组件el-scrollbar
前端·javascript·vue.js
C澒1 小时前
前端整洁架构(Clean Architecture)实战解析:从理论到 Todo 项目落地
前端·架构·系统架构·前端框架
C澒1 小时前
Remesh 框架详解:基于 CQRS 的前端领域驱动设计方案
前端·架构·前端框架·状态模式
Charlie_lll2 小时前
学习Three.js–雪花
前端·three.js
onebyte8bits2 小时前
前端国际化(i18n)体系设计与工程化落地
前端·国际化·i18n·工程化
C澒2 小时前
前端分层架构实战:DDD 与 Clean Architecture 在大型业务系统中的落地路径与项目实践
前端·架构·系统架构·前端框架
BestSongC2 小时前
行人摔倒检测系统 - 前端文档(1)
前端·人工智能·目标检测
0思必得03 小时前
[Web自动化] Selenium处理滚动条
前端·爬虫·python·selenium·自动化