基于webpack.config。js参数详解

  

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 ']   }      

基于webpack.config。js参数详解