webpack二(以webpack4.x起步)

614 阅读5分钟

一.基本安装

首先我们要创建一个目录,初始化npm,以及在本地安装webpack:
mkdir webpackapp && cd webpackapp
npm init -y
npm install --save-dev webapck
现在我们看一下我们创建的目录以及目录下的结构

二.简单实用webpack

我们先全局安装webpack: npm install -g webpack
此时,我们可以执行命令:webpack -v来查看webpack的版本号。
我们在根目录下新建一个文件:hello.js,并在其中输入代码。
function hello(str) { alert(str); } hello('hello world!');
这时,我们在命令行中输入:
webpack hello.js bundle.js
然而,预期的结果和想象的不一样:
The CLI moved into a separate package: webpack-cli Would you like to install webpack-cli? (That will run npm install -D webpack-cli) (yes/NO)
The CLI moved into a separate package:webpack-cli. Please install 'webpack-cli' in addition to webpack itself to use the CLI. ->when using npm: npm install webpack-cli -D ->when using yarn: yarn add webpack-cli -D
报出这两种任意一种的结果的意思是什么呢? 翻译成中文: CLI(命令行工具)已经转移到了一个单独的包webpack-cli中。 除了webpack自身外,请额外安装webpack-cli来使用CLI。 -> 使用npm安装:npm install webpack-cli -D ->使用yarn安装:yarn add webpack-cli -D
也就是说,在以前的webpack版本中CLI(命令行工具)是存在于webpack中的,而现在呢,它自己独立出来了,单独地放在一个单独webpack-cli包中。所以呢,现在想要使用CLI(命令行工具)就必须安装webpack-cli才行。
安装webpack-cli:
npm install webpack-cli -D
再次运行:
webpack hello.js bundle.js
发现还是报出:
The CLI moved into a separate package: webpack-cli Would you like to install webpack-cli? (That will run npm install -D webpack-cli) (yes/NO)
这时,我们就要全局安装webpack-cli:
npm install webpack-cli -g
现在,我们再试一下。
webpack hello.js bundle.js
结果又出现了新情况:
WARNING in configuration The 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable defaults for each environment. You can also set it to 'none' to disable any default behavior. Learn more: https://webpack.js.org/concepts/mode/ ERROR in multi ./hello.js bundle.js Module not found: Error: Can't resolve 'bundle.js' in 'C:\Users\Administrator\Desktop\webpackapp' @ multi ./hello.js bundle.js
翻译成中文: 配置警告: “mode”选项尚未设置。将“mode”选项设为“development”或“production”以启用此环境的默认设置。 multi错误 ./ hello.js bundle.js 未发现模块:错误:无法解析’C:/Users/你的用户名/Desktop/webpack-test’中的bundle.js @ multi ./hello.js bundle.js
这里的提示就是告诉我们,存在的第一个问题就是没有配置webpack的mode选项,默认的有production和development两种模式可以设置,因此我们尝试设置为development模式,在命令行中输入:
webpack --mode development
我们看到进行了打包并显示了Hash、Version、Time、Build at信息,表明已经可以打包。不过,仍然有错误提示:
ERROR in Entry module not found: Error: Can't resolve './src' in 'C:\Users\Administrator\Desktop\webpackapp'
翻译成中文:
未找到入口模块发生错误:错误:无法解析:'C:\Users\Administrator\Desktop\webpackapp'
它的意思就是,表明webpack4.x是以项目根目录下的'./src'作为入口,但是我们的项目中缺乏该路径,因此我们在根目录下创建一个src文件夹,事实上,webpack4.x以'./src/index.js'作为入口,单单创建src文件夹而没有index.js文件仍然会报错,因此我们:
将hello.js移动到'./src'中,并重新命名为'index.js'.
我们在运行一次: webpack index.js bundle.js
它还会提示can.t resolve相关的错误。
这种错误的原因是:webpack4.x的打包已经不能用'webpack 文件a 文件b' 这种方式打包了,而是在命令行中直接运行'webpack --mode development'或者'webpack --mode production'这种方式来完成打包。其中,入口文件是'./src/index.js',输出路径是'./dist/main.js'。其中,src目录中的index.js文件需要我们手动的去创建,而dist目录及dist目录下的main.js文件它会自动生成。所以说呢,这种'webpack 文件a 文件b'的打包方式已经不适用了,而是改为直接运行:
webpack --mode development
webpack --mde production
出现下面这种情况说明打包成功:
C:\Users\Administrator\Desktop\webpackapp>webpack --mode development Hash: c66758f7d1a4004b7b60 Version: webpack 4.5.0 Time: 608ms Built at: 2018-4-6 00:42:40 Asset Size Chunks Chunk Names main.js 2.88 KiB main [emitted] main Entrypoint main = main.js [./src/index.js] 65 bytes {main} [built]

不过每次都要输入这个命令,非常麻烦,我们在package.jsonscripts中加入两个成员:

"scripts": { "test": "echo \"Error: no test specified\" && exit 1", "dev":"webpack --mode development", "build":"webpack --mode production" }
以后在打包的过程中,我们只需要执行npm run dev就相当于执行webpack --mode development, 执行npm run build就相当于执行webpack --mode production
我们如果需要配置webpack指令的其他参数,只需要在webpack –mode production/development后加上其他参数即可,如: webpack --mode development --watch --progress --display-modules --colors --display-reasons
当然,这也可以写入package.json的scripts之中。
总结: 我们可以将以上探索进行整理总结,首先是注意事项: 1、webpack-cli必须要全局安装,否则不能使用webpack指令; 2、webpack也必须要全局安装,否则也不能使用webpack指令。 3、webpack4.x中webpack.config.js这样的配置文件不是必须的。 4、默认入口文件是./src/index.js,默认输出文件./dist/main.js。
配置步骤: 1、创建工程目录; 2、初始化工程目录:npm init。 3、全局安装webpack-cli。 4、全局安装webpack。 5、webpack –mode development/production进行打包,可在package.json中配置dev和build的脚本,便只需运行npm run dev/build,作用相同。 6、在webpack –mode development/production可串联设置其他参数。

今天就讲到这里吧,后续会继续更新,别忘了关注了哦!