webpack入门(2) - 安装,配置,环境搭建
栏目: JavaScript · 发布时间: 6年前
内容简介:我们只需要输入然后我们只需要需要注意的是,“start”在npm中比较特殊,只需npm start 就可以执行命令。如果是非start,还要再在前面加上一个run ,比如npm run dev,npm run build
- 在文件夹下新建一个
src文件,下面新建一个main.js文件。 - 根目录下新建一个
webpack.config.js文件。为什么要建这个文件,因为直接使用webpack,它会寻找webpack.config.js把它当成默认的配置去运行。此时它不需要指定任何参数,就能读取里面的内容。
// webpack.config.js
module.exports = {
entry: __dirname + '/src/main.js',//我指定了入口文件,在src/main.js
output: {
path: __dirname + '/dist', //打包后指定存放的目录,放在dist
filename: 'bundle.js' //打包后的文件叫bundle.js
}
}
复制代码
__dirname是Node.js中一个全局变量,它指向当前执行脚本所在的目录。
有多个入口文件的时候:
- 如果你一开始你就不想运行默认的
webpack.config.js,你想运行其他的配置文件,比如config.js文件。你可以运行webpack --config config.js,这样它就会寻找config.js,并且运行它。 - 运行
webpack,它会自动的寻找webpack.config.js,找到其中的入口文件比如上面的main.js。 - 如果你想有些个性化的需求,你想看到打包的进度,打包的模块,模块的信息,打包的原因。你可以输入以下的命令。
webpack --progress webpack --progress --display-modules webpack ---progress --display-modules --display-reasons
- 但是这种方法太过繁琐,你要在命令行输入这么多东西。那么有没有更轻松的方法呢? 有的!
- 在你初始化的时候,系统会自动生成
package.json。现在找到根目录下的package.json文件。 - 在里面的
scripts下添加定义一个脚本,
"dev":"webpack --config webpack.config.js --progress --display-modules --colors --display-reasons" 复制代码
- 最后在命令行运行
npm run dev因为scripts脚本提供了命令的“别名”,像上面的以一个“dev”命令代替了一连串的命令,使用起来更为方便 ,即便你没有在命令行输入以上的配置,你依然可以看到打包的进度;以看到打包有几个模块,模块的信息;字体为彩色;打包的原因。因为你在配置文件下定义了,就不需要了。
- 在你初始化的时候,系统会自动生成
更快捷的执行打包任务
- 最原始的执行打包任务,可以使用命令
webpack main.js bundle.js在这个例子当中,main.js是入口文件,bundle.js打包完之后的文件。 - 第二种,我们可以在
webpack.config.js里写配置。
module.exports = {
entry: __dirname + "/app/main.js",//唯一入口文件
output: {
path: __dirname + "/public",//打包后的文件存放的地方
filename: "bundle.js"//打包后输出文件的文件名
}
}
复制代码
我们只需要输入 webpack 命令,webpack就能自己找到 webpack.config.js ,在找出入口,找到output,执行打包。
- 第三种,继承第二种。更简单快捷的执行打包。在
package.json里找到“scripts”脚本,添加
"start": "webpack --config webpack.config.js --progress --display-modules --colors --display-reasons" 复制代码
然后我们只需要 npm start 就可以打包了。
需要注意的是,“start”在npm中比较特殊,只需npm start 就可以执行命令。如果是非start,还要再在前面加上一个run ,比如npm run dev,npm run build
搭建开发环境
使用source maps进行调试调试
为何要使用source maps?
因为 webpack 对源代码进行打包后,会对源代码进行压缩、精简、甚至变量名替换,在浏览器中,无法对代码逐行打断点进行调试,所有需要使用 source maps 进行调试,它使得我们在浏览器中可以看到源代码,进而逐行打断点调试。
如何使用source maps?
在配置中添加 devtool 属性,赋值为 source-map 或者 inline-source-map 即可,后者报错信息更加具体,会指示源代码中的具体错误位置,而 source-map 选项无法指示到源代码中的具体位置。
使用开发工具
用开发 工具 可以简化开发过程的工作。比如你写完代码后保存开发工具可以自动帮你执行一系列的命令。
watch模式
在使用 webpack-cli 进行打包时,通过命令 webpack --watch 即可开启 watch 模式,进入 watch 模式之后,一旦依赖树中的某一个模块发生了变化, webpack 就会重新进行编译。
使用webpack-dev-server
浏览器监听你的代码的修改,并自动刷新显示修改后的结果。它是一个单独的组件,在webpack中进行配置之前需要单独安装它作为项目依赖。
npm install --save-dev webpack-dev-server devServer
// webpack.config.js
module.exports = {
devServer: {
contentBase: './dist',//本地服务器所加载的页面所在目录
historyApiFallback: true,//不跳转
inline: true //实时刷新
}
};
复制代码
- 在
package.json添加脚本
// package.json
{
"scripts": {
"start": "webpack-dev-server --open"
}
}
复制代码
npm run start
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
PHP实战
Dagfinn Reiersol、Marcus Baker、Chris Shiflett / 张颖 等、段大为 审校 / 人民邮电出版社 / 2010-01 / 69.00元
“对于那些想要在PHP方面更进一步的开发者而言,此书必不可少。” ——Gabriel Malkas, Developpez.com “简而言之,这是我所读过的关于面向对象编程和PHP最好的图书。……强烈推荐此书,绝不要错过!” ——Amazon评论 “此书是理论与实践的完美融合,到目前为止,其他任何图书都无法与它相媲美。如果5颗星是满分,它完全值得10颗星!” ——A......一起来看看 《PHP实战》 这本书的介绍吧!