当前位置:首页>编程日记>正文

webpack 最简打包结果分析

本站寻求有缘人接手,详细了解请联系站长QQ1493399855

原文链接:https://ssshooter.com/2019-02...

现在的 webpack 不再是入门噩梦,过去 webpack 最让人心塞的莫过于配置文件,而 webpack4 诞生随之而来的是无配置 webpack。

使用 webpack4,至少只需要安装 webpack 和 webpack cli。所以大家完全可以自己打一个最简单的包,还能修改插件对比前后的区别。

npm i webpack webpack-cli -D 安装后,因为 webpack4 会默认 src 为入口目录,所以先新建 src/index.js

// src/index.js
import { sth } from './shouldImport'
import other from './shouldImport'let test = 'this is a variable'export default {a: test + ',' + sth,other,
}

为了更了解 webpack  导入机制所以再新建 src/shouldImport.js

// src/shouldImport.js
export let sth = 'something you need'export default {others: '',
}

然后运行 node_modules/.bin/webpack --mode development 即可在 dist/main.js 看到打包后的文件。

但是默认设置中模块文件会被 eval 包裹导致不便查看,所以需要再在设置做一点修改,把 devtool 属性改为 'source-map'

// 在根目录新建 webpack.config.js 文件
module.exports = mode => {if (mode === 'production') {return {}}return {devtool: 'source-map',}
}

然后再打包应该就能看到类似一下的文件结构,开发环境下打包得到的文件自带注释,理解起来不难:

;(function(modules) {// webpackBootstrap// The module cache 模块缓存var installedModules = {}// The require function 请求函数function __webpack_require__(moduleId) {// Check if module is in cache// 检查模块是否在缓存if (installedModules[moduleId]) {return installedModules[moduleId].exports}// Create a new module (and put it into the cache)// 创建新模块并放进缓存var module = (installedModules[moduleId] = {i: moduleId,l: false,exports: {},})// Execute the module function// 执行模块函数(有点不懂为什么 this 要传入 module.exports)modules[moduleId].call(module.exports, // thismodule, // 模块对象本身module.exports, // 模块对象的 exports 属性__webpack_require__ // 请求函数最终返回模块输出,传入用于请求其他模块)// Flag the module as loaded// 加载完成标志module.l = true// Return the exports of the module// 返回模块的输出return module.exports}// expose the modules object (__webpack_modules__)// 暴露所有模块对象__webpack_require__.m = modules// expose the module cache// 暴露模块缓存__webpack_require__.c = installedModules// Object.prototype.hasOwnProperty.call__webpack_require__.o = function(object, property) {return Object.prototype.hasOwnProperty.call(object, property)}// define getter function for harmony exports// 为 ES6 export 定义 getter 函数__webpack_require__.d = function(exports, name, getter) {if (!__webpack_require__.o(exports, name)) {// 检查属性是否存在Object.defineProperty(exports, name, { enumerable: true, get: getter })}}// define __esModule on exports// 于 export 定义 __esModule__webpack_require__.r = function(exports) {if (typeof Symbol !== 'undefined' && Symbol.toStringTag) {Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' })}Object.defineProperty(exports, '__esModule', { value: true })}// create a fake namespace object// 创建代用命名空间对象// mode & 1: value is a module id, require it// value 是模块 id,必要// mode & 2: merge all properties of value into the ns// 合并 value 所有属性到 ns// mode & 4: return value when already ns object// ns 已经是对象时返回 value// mode & 8|1: behave like require// 表现如 require__webpack_require__.t = function(value, mode) {if (mode & 1) value = __webpack_require__(value)if (mode & 8) return valueif (mode & 4 && typeof value === 'object' && value && value.__esModule)return valuevar ns = Object.create(null)__webpack_require__.r(ns)Object.defineProperty(ns, 'default', { enumerable: true, value: value })if (mode & 2 && typeof value != 'string')for (var key in value)__webpack_require__.d(ns,key,function(key) {return value[key]}.bind(null, key))return ns}// getDefaultExport function for compatibility with non-harmony modules// 用于兼容非 ES6 模块的 getDefaultExport 函数__webpack_require__.n = function(module) {var getter =module && module.__esModule? function getDefault() {return module['default']}: function getModuleExports() {return module}__webpack_require__.d(getter, 'a', getter)return getter}// __webpack_public_path____webpack_require__.p = ''// Load entry module and return exports// 加载入口模块并返回 exportreturn __webpack_require__((__webpack_require__.s = './src/index.js'))
})({'./src/index.js':/*! exports provided: default */function(module, __webpack_exports__, __webpack_require__) {'use strict'__webpack_require__.r(__webpack_exports__) // 于 export 定义 __esModule/* harmony import */var _shouldImport__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__('./src/shouldImport.js')let test = 'this is a variable'/* harmony default export */__webpack_exports__['default'] = {a: test + ',' + _shouldImport__WEBPACK_IMPORTED_MODULE_0__['sth'],other: _shouldImport__WEBPACK_IMPORTED_MODULE_0__['default'],}},'./src/shouldImport.js':/*! exports provided: sth, default */function(module, __webpack_exports__, __webpack_require__) {'use strict'__webpack_require__.r(__webpack_exports__)/* harmony export (binding) */__webpack_require__.d(__webpack_exports__, 'sth', function() {return sth})let sth = 'something you need'__webpack_exports__['default'] = {others: '',}},
})

源文件中的所有 importexport 都会转换为对应的辅助函数。

  • import 对应 __webpack_require__
  • export 对应 __webpack_exports__['default'] 直接赋值和 __webpack_require__.d

整理一下整个流程:

  1. 定义 __webpack_require__ 及其辅助函数
  2. 使用 __webpack_require__ 引入入口模块
  3. __webpack_require__ 函数载入模块,将模块放到模块缓存
  4. 调用模块

    1. 同样使用 __webpack_require__ 读取依赖(回到第 3 步)
    2. 运行模块内部功能
    3. 使用 __webpack_exports__['default'] 直接赋值和 __webpack_require__.d 输出
  5. 运行结束

http://www.coolblog.cn/news/3dc25729ff0e9e68.html

相关文章:

  • asp多表查询并显示_SpringBoot系列(五):SpringBoot整合Mybatis实现多表关联查询
  • s7day2学习记录
  • 【求锤得锤的故事】Redis锁从面试连环炮聊到神仙打架。
  • 矿Spring入门Demo
  • 拼音怎么写_老师:不会写的字用圈代替,看到孩子试卷,网友:人才
  • Linux 实时流量监测(iptraf中文图解)
  • Win10 + Python + GPU版MXNet + VS2015 + RTools + R配置
  • 美颜
  • shell访问php文件夹,Shell获取某目录下所有文件夹的名称
  • 如何优雅的实现 Spring Boot 接口参数加密解密?
  • LeCun亲授的深度学习入门课:从飞行器的发明到卷积神经网络
  • 法拉利虚拟学院2010 服务器,法拉利虚拟学院2010
  • Mac原生Terminal快速登录ssh
  • 支撑微博千亿调用的轻量级RPC框架:Motan
  • mysql commit 机制_1024MySQL事物提交机制
  • java受保护的数据与_Javascript类定义语法,私有成员、受保护成员、静态成员等介绍...
  • 2019-9
  • jquery 使用小技巧
  • vscode pylint 错误_将实际未错误的py库添加到pylint白名单
  • 科学计算工具NumPy(3):ndarray的元素处理
  • 工程师在工作电脑存 64G 不雅文件,被公司开除后索赔 41 万,结果…
  • linux批量创建用户和密码
  • js常用阻止冒泡事件
  • 气泡图在开源监控工具中的应用效果
  • newinsets用法java_Java XYPlot.setInsets方法代碼示例
  • 各类型土地利用图例_划重点!国土空间总体规划——土地利用
  • php 启动服务器监听
  • dubbo简单示例
  • Ubuntu13.10:[3]如何开启SSH SERVER服务
  • [iptables]Redhat 7.2下使用iptables实现NAT
  • Django View(视图系统)
  • 【设计模式】 模式PK:策略模式VS状态模式
  • CSS小技巧——CSS滚动条美化
  • JS实现-页面数据无限加载
  • 最新DOS大全
  • 阿里巴巴分布式服务框架 Dubbo
  • 阿里大鱼.net core 发送短信
  • Sorenson Capital:值得投资的 5 种 AI 技术
  • 程序员入错行怎么办?
  • Arm芯片的新革命在缓缓上演
  • 两张超级大表join优化
  • 第九天函数
  • Linux软件安装-----apache安装
  • HDU 5988 最小费用流
  • 通过Spark进行ALS离线和Stream实时推荐
  • 《看透springmvc源码分析与实践》读书笔记一
  • nagios自写插件—check_file
  • python3 错误 Max retries exceeded with url 解决方法
  • 正式开课!如何学习相机模型与标定?(单目+双目+鱼眼+深度相机)
  • 行为模式之Template Method模式