01-Vue源码的构建过程解析之scripts/build.js

const fs = require('fs') // node内建的文件系统模块
const path = require('path') // node内建的路径模块
const zlib = require('zlib') // 用来压缩的
const rollup = require('rollup') // 没什么好说的
const terser = require('terser') // 不知道干啥的

// 保证dist目录存在
if (!fs.existsSync('dist')) {
  fs.mkdirSync('dist')
}

// 获取全部的构建配置
let builds = require('./config').getAllBuilds()

// 根据命令行获取要构建的目标,如果没有则构建全部目标(不包括weex)
// filter builds via command line arg
if (process.argv[2]) {
  const filters = process.argv[2].split(',')
  builds = builds.filter(b => {
    return filters.some(f => b.output.file.indexOf(f) > -1 || b._name.indexOf(f) > -1)
  })
} else {
  // filter out weex builds by default
  builds = builds.filter(b => {
    return b.output.file.indexOf('weex') === -1
  })
}

// 开始构建
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)
  // 其实这段代码的详细我是没看懂的,有疑问的,但是这个不影响我理解大概,我不想看rollup的东西了
  return rollup.rollup(config)
    .then(bundle => bundle.generate(output))
    .then(({ output: [{ code }] }) => {
      if (isProd) {
        const minified = (banner ? banner + '\n' : '') + terser.minify(code, {
          toplevel: true,
          output: {
            ascii_only: true
          },
          compress: {
            pure_funcs: ['makeMap']
          }
        }).code
        return write(file, minified, true)
      } else {
        return write(file, code)
      }
    })
}

function write (dest, code, zip) {
  return new Promise((resolve, reject) => {
    function report (extra) {
      console.log(blue(path.relative(process.cwd(), dest)) + ' ' + getSize(code) + (extra || ''))
      resolve()
    }

    fs.writeFile(dest, code, err => {
      if (err) return reject(err)
      if (zip) {
        zlib.gzip(code, (err, zipped) => {
          if (err) return reject(err)
          report(' (gzipped: ' + getSize(zipped) + ')')
        })
      } else {
        report()
      }
    })
  })
}

// 以kb的格式获取大小
function getSize (code) {
  return (code.length / 1024).toFixed(2) + 'kb'
}

function logError (e) {
  console.log(e)
}

function blue (str) {
  return '\x1b[1m\x1b[34m' + str + '\x1b[39m\x1b[22m'
}

觉得好的给我点赞哦:)

in ./src/views/modules/orders/add-or-update.vue?vue&type=style&index=0&lang=scss& Module build failed (from ./node_modules/postcss-loader/src/index.js): TypeError: Cannot read properties of undefined (reading 'toString') at new Input (E:\DevTools\DevCode\VueCode\vueflower\node_modules\postcss\lib\input.js:53:20) at parse (E:\DevTools\DevCode\VueCode\vueflower\node_modules\postcss\lib\parse.js:13:15) at new LazyResult (E:\DevTools\DevCode\VueCode\vueflower\node_modules\postcss\lib\lazy-result.js:60:16) at Processor.<anonymous> (E:\DevTools\DevCode\VueCode\vueflower\node_modules\postcss\lib\processor.js:138:12) at Processor.process (E:\DevTools\DevCode\VueCode\vueflower\node_modules\postcss\lib\processor.js:117:23) at E:\DevTools\DevCode\VueCode\vueflower\node_modules\postcss-loader\src\index.js:141:8 @ ./node_modules/vue-style-loader??ref--8-oneOf-1-0!./node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!./node_modules/vue-loader/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/src??ref--8-oneOf-1-2!./node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/views/modules/orders/add-or-update.vue?vue&type=style&index=0&lang=scss& 4:14-480 14:3-18:5 15:22-488 @ ./src/views/modules/orders/add-or-update.vue?vue&type=style&index=0&lang=scss& @ ./src/views/modules/orders/add-or-update.vue @ ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/views/modules/orders/list.vue?vue&type=script&lang=js& @ ./src/views/modules/orders/list.vue?vue&type=script&lang=js& @ ./src/views/modules/orders/list.vue @ ./src/router/router-static.js @ ./src/main.js @ multi (webpack)-dev-server/client?http://192.168.1.17:8081/sockjs-node (webpack)/hot/dev-server.js ./src/main.js
09-18
### 获取 Vue 3 源码并理解其结构 Vue 3 的源码可以通过多种方式获取,其中一种常见且便捷的方式是通过 [UNPKG](https://unpkg.com/) 这样的 CDN 服务访问 Vue 的发布版本。例如,可以通过访问 `https://unpkg.com/vue@3/dist/vue.global.js` 来获取 Vue 3 的全局构建版本[^1]。该文件是经过打包处理的 Vue 3 核心代码,适合在浏览器环境中直接使用。 如果希望深入研究 Vue 3 的源码结构,推荐访问 Vue 的官方 GitHub 仓库:[https://github.com/vuejs/core](https://github.com/vuejs/core)。该仓库包含了完整的源码结构,主要采用 TypeScript 编写,并按照模块化的方式组织代码。核心模块包括: - **reactivity**:实现响应式系统的核心代码,包括 `ref`、`reactive`、`effect` 等 API。 - **runtime-core**:Vue 渲染器的核心逻辑,与平台无关。 - **runtime-dom**:基于 `runtime-core`,实现与浏览器 DOM 相关的渲染逻辑。 - **runtime-test**:用于单元测试的轻量级渲染器。 - **compiler-core**:模板编译器的核心逻辑,与平台无关。 - **compiler-dom**:基于 `compiler-core`,实现与浏览器 HTML 相关的模板编译逻辑。 - **vue**:构建最终的 `vue.js` 文件,集成所有模块。 Vue 3 的源码采用 Monorepo 结构管理多个子项目,使用 [TypeScript](https://www.typescriptlang.org/) 和 [Rollup](https://rollupjs.org/) 作为构建工具,支持模块化开发与打包。 ### 源码调试与开发环境搭建 为了调试 Vue 3 的源码,可以通过克隆官方仓库并配置开发环境。具体步骤如下: 1. 克隆仓库: ```bash git clone https://github.com/vuejs/core.git cd core ``` 2. 安装依赖: ```bash npm install ``` 3. 构建源码: ```bash npm run build ``` 4. 运行测试: ```bash npm run test ``` 该流程可确保源码构建成功,并通过测试验证功能完整性[^1]。 ### 使用 Vue 3 源码构建项目 在实际项目中使用 Vue 3 源码,通常推荐通过构建工具如 [Vite](https://vitejs.dev/) 或 [Webpack](https://webpack.js.org/) 引入模块化版本。例如,在 Vite 项目中可以直接通过 `import vue from 'vue'` 引入 Vue 模块,并使用其提供的 Composition API 开发组件化应用[^1]。 ```javascript import { createApp, ref } from 'vue' const app = createApp({ setup() { const count = ref(0) return { count } } }) app.mount('#app') ``` ### 源码结构与构建流程的优化 Vue 3 的构建流程支持多种构建目标,包括全局构建、ES 模块构建、SSR 构建等。通过修改 `package.json` 中的 `build` 脚本,可以自定义构建行为,例如上传构建产物到 CDN 服务器: ```json "build": "vite build && node ./scripts/upcdn.js" ``` 此配置可在构建完成后执行额外的上传脚本,实现自动化部署[^3]。 ### 拓展应用 Vue 3 的模块化设计使其易于与其他库集成,例如通过 `Vue.use()` 注册插件: ```javascript import Chartkick from 'chartkick' import VueChartkick from 'vue-chartkick' Vue.use(VueChartkick, { Chartkick }) ``` 这种模式支持快速集成第三方功能模块,扩展 Vue 应用的能力[^4]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值