webpack.config.js文件通常放在项目的根目录中,它本身也是一个标准的Commonjs规范的模块。
var webpack=要求(“webpack”); 模块。出口={ 条目:[ “webpack/热/only-dev-server”, “/js/app.js。” ), 输出:{ 路径:“。/构建”, 文件名:“bundle.js” }, 模块:{ 加载器:( {测试:/\ . js # 63;美元/,加载器:“react-hot”,“巴别塔”,排除:/node_modules/}, {测试:/\。js/美元,排除:/node_modules,装载机:babel-loader}, {测试:/\。css/美元,装载机:“风格!css "}, {测试:/\。少/,装载机:“style-loader css-loader ! less-loader”} ] }, 解决:{ 扩展:[",' . js ', ' . json '] }, 插件:[ 新的webpack.NoErrorsPlugin () ]};
条目可以是个字符串或数组或者是对象。
当条目是个字符串的时候,用来定义入口文件:
条目:“。/js/main.js”
当条目是个数组的时候,里面同样包含入口js文件,另外一个参数可以是用来配置webpack提供的一个静态资源服务器,webpack-dev-server.webpack-dev-server会监控项目中每一个文件的变化,实时的进行构建,并且自动刷新页面:
条目:[ “webpack/热/only-dev-server”, ”。/js/app.js”
当条目是个对象的时候,我们可以将不同的文件构建成不同的文件,按需使用,比如在我的你好页面中只要\引入hello.js即可:
条目:{ 你好:“。/js/hello.js ', 形式:“/js/form.js。” }
输出参数是个对象,用于定义构建后的文件的输出。其中包含路径和文件名:
输出:{ 路径:“。/构建”, 文件名:“bundle.js” }
当我们在条目中定义构建多个文件时,文件名可以对应的更改为[名字]. js用于定义不同文件构建后的名字。
关于模块的加载相关,我们就定义在module.loaders中。这里通过正则表达式去匹配不同后缀的文件名,然后给它们定义不同的加载器。比如说给少文件定义串联的三个加载器(!用来定义级联关系):
模块:{ 加载器:( {测试:/\ . js # 63;美元/,加载器:“react-hot”,“巴别塔”,排除:/node_modules/}, {测试:/\。js/美元,排除:/node_modules,装载机:babel-loader}, {测试:/\。css/美元,装载机:“风格!css "}, {测试:/\。少/,装载机:“style-loader css-loader ! less-loader”} ] }
此外,还可以添加用来定义png, jpg这样的图片资源在小于10 k时自动处理为base64图片的加载器:
{测试:/\ (png | jpg)/美元,装载机:“url-loader& # 63;限制=10000}
给css和少还有图片添加了装载机之后,我们不仅可以像在节点中那样需要js文件了,我们还可以需要css,甚少至图片文件:
要求('/bootstrap.css。'); 要求('/myapp.less。'); var img=document.createElement (img); img。src=https://www.yisu.com/zixun/require (’。/glyph.png ');
但是需要知道的是,这样需要来的文件会内联到js包中。如果我们需要把保留需要的写法又想把css文件单独拿出来,可以使用下面提到的[extract-text-webpack-plugin]插件。
在上面示例代码中配置的第一个加载器我们可以看到一个叫做react-hot的加载器。我的项目是用来学习写反应相关代码的,所以配置了一个react-hot加载器,通过它,可以实现对反应组件的热替换。我们已经在条目参数中配置了webpack/热/only-dev-server,所以我们只要在启动webpack开发服务器时开启热参数,就可以使用react-hot-loader了。在package.json文件中这样定义:
"脚本":{ “开始”:“webpack-dev-server——热——发展——颜色”, “构建”:“webpack——发展——颜色” }
webpack在构建包的时候会按目录的进行文件的查找,解决属性中数的扩展组中用于配置程序可以自行补全哪些文件后缀:
解决:{ 扩展:[",' . js ', ' . json '] }