前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >webpack打包原理入门探究(三)入口探究

webpack打包原理入门探究(三)入口探究

作者头像
公众号---人生代码
发布2020-06-02 16:57:23
4570
发布2020-06-02 16:57:23
举报
文章被收录于专栏:人生代码人生代码

上面我们已经讲过了两节课了,感兴趣的伙伴,可以看看上面两节课的内容,大神勿扰,欢迎评论,给我提出更好的建议,谢谢。

webpack打包原理入门探究(二)基本配置

webpack打包原理入门探究(一)

接着上面一节课,进入 entry,output 配置的研究

entry,从字面的意思是 入口的意思,入口可能是单个,也可能是多个

output,也可能是单个输出,也可能是多个输出

多个入口以数组形式,对单个输出

我们在根目录新建一个 webpack.entry.config.js

代码语言:javascript
复制
let path = require('path')
function resolve(o) {
    return path.resolve(__dirname, o)
}
module.exports = {
    entry: [resolve('src/scripts/main.js'), resolve('src/scripts/a.js')], // 指定入口文件
    output: {
        path: resolve('dist/js'),
        filename: 'main.bundle.js'
    }
}

配置 package.json

执行

代码语言:javascript
复制
npm run webpack.entry

多个入口以对象形式,对单个输出(报错)

代码语言:javascript
复制
let path = require('path')
function resolve(o) {
    return path.resolve(__dirname, o)
}
module.exports = {
    entry: {
        main: resolve('src/scripts/main.js'),
        a: resolve('src/scripts/a.js')
    }, // 指定入口文件
    output: {
        path: resolve('dist/js'),
        filename: 'main.object.bundle.js'
    }
}

配置 package.json

执行

代码语言:javascript
复制
npm run webpack.entry.object

最终只输出一个 文件,其实是被 a 入口覆盖掉了 main.object.bundle.js

代码语言:javascript
复制
/******/ (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
/******/ 		modules[moduleId].call(module.exports, module, module.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;
/******/
/******/ 	// define getter function for harmony exports
/******/ 	__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
/******/ 	__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
/******/ 	// mode & 2: merge all properties of value into the ns
/******/ 	// mode & 4: return value when already ns object
/******/ 	// mode & 8|1: behave like require
/******/ 	__webpack_require__.t = function(value, mode) {
/******/ 		if(mode & 1) value = __webpack_require__(value);
/******/ 		if(mode & 8) return value;
/******/ 		if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ 		var 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
/******/ 	__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;
/******/ 	};
/******/
/******/ 	// Object.prototype.hasOwnProperty.call
/******/ 	__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ 	// __webpack_public_path__
/******/ 	__webpack_require__.p = "";
/******/
/******/
/******/ 	// Load entry module and return exports
/******/ 	return __webpack_require__(__webpack_require__.s = "./src/scripts/a.js");
/******/ })
/************************************************************************/
/******/ ({

/***/ "./src/scripts/a.js":
/*!**************************!*\
  !*** ./src/scripts/a.js ***!
  \**************************/
/*! no static exports found */
/***/ (function(module, exports) {

eval("console.log(\"hhhhhhh\")\n\n//# sourceURL=webpack:///./src/scripts/a.js?");

/***/ })

/******/ });

接下来,我们修改一下 output 的输出方式

代码语言:javascript
复制
let path = require('path')
function resolve(o) {
    return path.resolve(__dirname, o)
}
module.exports = {
    entry: {
        main: resolve('src/scripts/main.js'),
        a: resolve('src/scripts/a.js')
    }, // 指定入口文件
    output: {
        path: resolve('dist/js'),
        filename: '[name]-[hash].js'
    }
}

执行 npm run webpack.entry.object 之后,生成两个文件,但是他们的hash 值是一样的

如果我改成这样会如何呢?

代码语言:javascript
复制
let path = require('path')
function resolve(o) {
    return path.resolve(__dirname, o)
}
module.exports = {
    entry: {
        main: resolve('src/scripts/main.js'),
        a: resolve('src/scripts/a.js')
    }, // 指定入口文件
    output: {
        path: resolve('dist/js'),
        filename: "[name]-[chunkhash].js"
    }
}

执行 npm run webpack.entry.object,之后,hash 值不一样了

ok,这节课就暂时讲到这里吧

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-05-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 CryptoCode 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 多个入口以数组形式,对单个输出
  • 多个入口以对象形式,对单个输出(报错)
  • 接下来,我们修改一下 output 的输出方式
  • 如果我改成这样会如何呢?
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档