webpack前段时间有据说一下,如今已经到了3.x的版本,本身没去接触。由于以前使用gulp来做为本身的项目构建工具。如今感受gulp使用的趋势在减小。如今这段时间去接触了webpack,感受很不错,它的模块化打包机制,对前端开发和性能方面都带来好处。这里不是说gulp很差,二者不做比较css
接下来会说说本身对webpack使用的感觉,我不会一步步写出使用webpack的流程,由于关于webpack的教程有不少,但会写一些关键地方,注意地方,来加深对webpack的看法。html
学习就是这样,东看看西看看,看人家的对某件东西的看法,加上本身的理解,是否异同,慢慢积累,最终成为本身的知识。前端
webpack 是一个现代 JavaScript 应用程序的模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序须要的每一个模块,而后将全部这些模块打包成少许的 bundle - 一般只有一个,由浏览器加载。
它是高度可配置的,可是,在开始前你须要先理解四个核心概念:入口(entry)、输出(output)、loader、插件(plugins)。node
这里说了这么多就是它能把项目中资源文件当作一个个模块,而后将他们打包成少许或一个文件,而后咱们去引用这文件。webpack
你们这里可能会疑惑,当时我也想,怎么能作到这个?怎么就打包成一个文件了?那么js,css,图片什么的怎么搞?还有这种操做?我能怎么办,那只能选择相信它。git
其实学习某同样工具,咱们只须要知道这东西能作什么,而后怎么用它,但它具体实现的细节,有时咱们没必要深究。咱们只需知其然,没必要知其因此然。尽管去用这个东西,它原本就是一个工具。就比如开一辆车,咱们只需去学习怎么开,而不用太在乎他为何能开,开多了同样成为老司机,不是吗,没毛病吧。工具它能给咱们带来便利,就足够了。除非你是制造工具的。可是若是对webpack很是感兴趣,能够去它的github上看看。es6
上面说webpack能打包模块,其实还有不少功能。github
上面举例是经常使用,其功能还多得多。都是经过webpack 的 loader和plugins实现的,能够说是很强大了。web
//全局安装 npm install -g webpack //建立一个文件夹 mkdir webpack-demo //进入项目中 cd webpack-demo //初始化,生成默认package.json 文件 npm init -y //在当前项目中安装webpack npm install webpack --save-dev //到这里就安装成功了
感觉:整个流程和安装gulp差很少,是npm模块的那套安装流程。
说到npm,在国内推荐使用cnpm淘宝镜像,很不错,速度快不少。还有能够逛npm的官网去查询本身想要看的模块,里面都有模块的详细介绍。npm
// 安装css-loader npm install css-loader --save-dev // 安装htmlWebpackPlugin npm install html-webpack-plugin --save-dev
//引入模块 const webpack = require('webpack'); const path = require('path'); const htmlWebpackPlugin = require('html-webpack-plugin'); //配置 const config = { entry: './path/to/my/entry/file.js', output: { path: path.resolve(__dirname, 'dist'), filename: 'my-first-webpack.bundle.js' }, module: { rules: [ { test: /\.css$/, use: 'css-loader' } ] }, plugins: [ new HtmlWebpackPlugin({template: './src/index.html'}) ] };
这个文件中关键的东西就是上述提到的:四个核心概念:入口(entry)、输出(output)、loader、插件(plugins)。弄懂这四个核心的东西,webpack也就懂得差很少了,起码懂得怎么用。