wepback风头正火 ,但是公司一直在用gulp,正好赶上年底活动,借此机会第一次尝试了webpack,说实话webpack真的很强大,内容一层一层递进。

这几天跟着官网跑了一遍,然后写了自己的配置文件,因为活动内容不多,很多强大的功能没有用上,但是相信对于入门来说足够了。

下面来总结并附上源码

当 webpack 处理应用程序时,它会递归地构建一个依赖关系图,其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。

webpack支持的模块语法有哪些?

ES6,CommonJs,Amd

webpack和gulp的区别?

Webpack可以通过众多loader和plugin完成许多gulp上的功能,但Webpack本质在于模块打包,而gulp的本质在于执行任务;使用webpack-stream包可以实现gulp和webpack的搭配使用

核心概念

1.入口:指定使用哪个模块来作为构建内部依赖图的开始,随后打包成bundle

2.输出:定义输出生产的bundle的位置及文件名;

3.loader:让webpack可以处理非js模块;loader 可以将所有类型的文件转换为webpack 能够处理的有效模块。

4. 插件:执行的任务范围包括从打包优化和压缩,一直到重新定义环境中的变量,目的在于完成一些loader无法完成的任务。

常用配置项

1.mode: ‘development’|| ‘production’ || ‘none’

2.entry:  array || obj

3.output: {

  path: path.resolve(__dirname, "dist"), // 输出文件的目标路径

  filename:’bundle.js’,// 打包后的文件名

  publicPath: ‘static’// 输出解析文件目录,url相对于html

}

4.module: {

  rules: [

    {

test: /\.js$/, // 指定使用此loader的文件

use: ‘babel-loader’,

options: { },

include: /src/, // 匹配项

      exclude: /node_modules/ // 非匹配项

    }

    ]

  }

5.plugins: […instance]

6.devServer: {

  host: ‘localhost’,

  port: ‘8080’,

  contentBase: Boolean|| string || array, // 服务器从哪里获取内容

  hot:boolean, // 是否开启webpack模块热替换

  open: Boolean, // 是否自动打开浏览器

  proxy: { path: targetUrl}, // 代理

    …others

  }

7.resolve: {

  alias: {

    test: url

    },

  extensions: [.js, .json]

 }

8.devtool: string || false

  可选值:

  cheap-eval-source-map

  eval-source-map

  cheap-source-map

  source-map

  cheap-module-eval-source-map

  …others

常用loaderplugin

loader

Css-loader:解析css中资源路径;

Sass-loader:sass转码为css

Postcss-loader:使webpack可以用postcss处理css

Px2rem-loader: px转换为rem

Style-loader:将css以style标签的形式插入到dom中

Babel-loader:转码js以提高兼容性

url-loader:图片转base64

webpack imagemin-webpack-plugin 压缩图片

file-loader:将文件输出到输出目录并返回文件路径

html-loader:处理html中资源路径

eslint-loader:使js支持eslint

plugin

html-webpack-plugin:根据模板导出html文件,并注入bundle

DinePlugin: 创建编译时可以进行配置的全局变量。

HashedModuleIdsPlugin: 根据模块的相对路径生成一个四位数的hash作为模块id

extract-text-webpack-plugin:分离css

mini-css-extract-plugin:分离css

uglifyjs-webpack-plugin:压缩js

optimize-css-assets-webpack-plugin:压缩css

clean-webpack-plugin: 清空某个目录

cli常用命令

--config 使用指定的配置文件

--env.key=value 指定环境变量

--mode=production 指定模式

--progress 打印编译进度的百分比

--display-error-details 展示错误细节

--define 定义环境变量

-w 观察文件变化,变化后重新执行构建流程

--hot 开启模块热替换

--json > stats.json 将编译结果的各种信息输出为json文件

--profile 捕获编译时每个步骤的时间信息

配置文件编写

前端常见需求:

  1)       Js压缩

  2)       Css压缩

  3)       Css提取

  4)       小图片转base64

  5)       Px转rem

  6)       Css前缀添加

  7)       Sass转码

  8)       Babel转码

  9)       文件名加hash

  10)       文件编码格式转换(常见utf-8与gbk互转)

  11)       代码分离

  12)       Eslint

  13)       模块热替换

  14)       配置编译过程的全局变量

  15)       打包后的代码注入html中

1.    常用模块变量

  __dirname:当前文件夹路径

2.    常用占位符

   [hash]:模块标识符的hash(后拼接:‘:n’可指定长度)

  [chunkhash]: chunk内容的hash(后拼接:‘:n’可指定长度)

  [name]:模块名称

  [id]: 模块标识符

3. 配置文件使用commonjs编写的,配置类型有下面几种:

   1) 导出一个配置对象

  2) 导出一个函数

  3) 导出一个promise

代码分离

该功能可以把代码分离到不同的 bundle 中,然后可以按需加载或并行加载这些文件。代码分离可以用于获取更小的 bundle,以及控制资源加载优先级,如果使用合理,会极大影响加载时间。

代码分离的方式:

  1.手动配置多个入口文件

  2.使用webpack自带的splitChunks功能

  3.使用import()动态导入

下面附上自己的web.config.js

//生成html文件 npm i -D html-webpack-plugin
const HtmlWebpackPlugin = require('html-webpack-plugin');
//每次打包前清理目录文件 npm i -D clean-webpack-plugin
const CleanWebpackPlugin = require('clean-webpack-plugin');
//js压缩 npm i -D uglifyjs-webpack-plugin
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
//单独打包css,webpack3是利用extract-text-webpack-plugin插件提取单独打包css文件
//webpack4得使用mini-css-extract-plugin npm i -D mini-css-extract-plugin
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
//压缩css npm i -D optimize-css-assets-webpack-plugin
const OptimizeCSSAssetsPlugin = require("optimize-css-assets-webpack-plugin");
//用于打包后的文件转码 npm i webpack-encoding-plugin
const EncodingPlugin = require("webpack-encoding-plugin");
//提取公共模块 请参考https://segmentfault.com/a/1190000012828879
//引入glob正则匹配多页面 npm i -D glob
var glob = require('glob');
//安装webpack npm i -D webpack@<version>(版本号)
//webpack4后将webpack-cli分别出来要自己安装 npm in -D webpack-cli
const webpack = require('webpack');
//处理文件路径的工具
const path = require('path');
//设置变量判断是开发环境还是生产环境 npm i -D cross-env
const devMode = process.env.NODE_ENV !== 'production';
//获取所有路口js,生成一个路径对象.
var getEntry = function () {
var entry = {};
  //首先我们先读取我们的开发目录
  glob.sync('./source/**/*.js').forEach(function (name) {
    var n = name.slice(name.lastIndexOf('source/') + 7, name.length - 3);
    n = n.slice(0, n.lastIndexOf('/'));
    //接着对路径字符串进行了一些裁剪成想要的路径
    entry[n] = name;
  });
  console.log(entry);
  /**
    *    entry = {
    *               'crowd/index' : './source/main/index/index.js',
    *               'index/index' : './source/content/index/index.js'
    *           }
  *
  **/
  //最后返回entry 给 webpack的entry
  return entry;
};
module.exports = {
  entry: getEntry(), //入口文件
  output: { //文件输出位置
  path: path.resolve(__dirname, 'dist'), //配置输出路径
    filename: "js/[name].bundle.js", //文件输出形式
    chunkFilename: "js/[name].chunk.js",
    publicPath: '/'//虚拟目录,自动指向path编译目录
},
//tips:chunkFilename网上觉得靠谱的解释
//chunkname是未被列在entry中,却又需要被打包出来的文件命名配置。什么场景需要呢?在按需加载(异步)模块的时候,
//这样的文件是没有被列在entry中的,如使用CommonJS的方式异步加载模块:
// require.ensure(["modules/tips.jsx"], function(require) {
// var a = require("modules/tips.jsx");
// // ...
// }, 'tips');
//tips:一般来说,引入第三方库有一下三种情况:
// 通过CDN引入;
// 通过npm 安装并引入;
// 第三方js文件就在本地
resolve: {//一些配置项,如第三方的js文件就在本地,怎么通过webpack引入
  alias: {
    $: path.resolve(__dirname, './dist/jquery.js'),
    jQuery: path.resolve(__dirname, './dist/jquery.js'),
  }
},
plugins: [ //插件
 
  require("autoprefixer"),//引入自动补全前缀,直接引入autoprefixer-loader并没有生效,
  //安装postcss-loader并引入autoprefixer时生效,并创建postcss.config.js文件
  new webpack.HotModuleReplacementPlugin(),//启动模块热替换
  new webpack.NamedModulesPlugin(), //用于启动HMR时可以显示模块的相对路径
  new UglifyJsPlugin({}),//js压缩
  new MiniCssExtractPlugin({//css分离
    filename: devMode ? 'css/[name].css' : 'css/[name].[hash:5].css',
    chunkFilename: devMode ? 'css/[id].css' : 'css/[id].[hash:5].css',
  }),
  new OptimizeCSSAssetsPlugin({}),//css压缩
  //多页应用时配置多个html时,那么就需要实例化该插件多次
  new HtmlWebpackPlugin({
    template: 'src/html/index.html',
    excludeChunks: ['list', 'detail']//配置不允许注入的chunk
  }),
  new HtmlWebpackPlugin({
    filename: 'list.html',
    template: 'src/html/list.html',
    chunks: ['common', 'list']//允许插入到模板中的一些chunk,不配置此项默认会将entry中所有的chunk注入到模板中
  }),
  new HtmlWebpackPlugin({
    filename: 'detail.html',
    template: 'src/html/detail.html',
    chunks: ['common', 'detail']
  }),
  //用来项目的转码
  new EncodingPlugin({
    encoding: 'GB2312'
  }),
  //清除dist文件夹
  new CleanWebpackPlugin(['dist'])
],
//模块
module: {
  rules: [
  {
    test: /\.js$/,
    use: [
    {
      loader: 'babel-loader',//cnpm i -D babel-loader @babel/core @babel/preset-env webpack
      options: {//npm i -S babel-polyfill 实现浏览器对不支持API的兼容(兼容旧环境、填补)
      presets: ['@babel/preset-env']
    }
  }
],
  exclude: /node_modules/
},
{
  test: /\.(sa|sc|c)ss$/,
  use: [//npm i -D style-loader css-loader
    devMode ? 'style-loader' : MiniCssExtractPlugin.loader,//因为MiniCssExtractPlugin不支持热替换,所以当是生产环境时不启用这个插件
    'css-loader',
    'postcss-loader',//npm i -D postcss-loader
    // {网上还有这种写法
    // loader: 'postcss-loader',
    // options: {
      // plugins: () => [
      // require('autoprefixer')
    // ],
  // }
// },
  'sass-loader',//使用sass-loader要使用node-loader,npm i -D sass-loader node-sass
  {
  loader: 'px2rem-loader',//配合flexible实现移动端下的适配 npm i px2rem-loader
  // options here
    options: {
      remUni: 75,
      remPrecision: 8
    }
  }
  ]
},
{
  test: /\.(jpg|png|gif|jpeg)$/,
  use: [ {//npm i -D url-loader
    loader: 'url-loader',// 在文件大小(单位 byte)低于指定的限制时,可以返回一个 DataURL。
    options: {
      limit: 10000,//设置字节限制
      name: 'img/[name]_[hash:5].[ext]'
    }
  } ]
 }
]
},
//配置开发服务功能 npm i -D webpack-dev-server
devServer: {
  contentBase: path.resolve(__dirname, 'dist'),
  historyApiFallback: true,
  hot: true,
  port: 9000,
  publicPath:'/',
  }
};

webpack4.0入门配置文件的更多相关文章

  1. webpack4.0入门总结

    1. 安装webpack: // 初始化.安装webpack以及webpack-clinpm init npm install --save-dev webpack webpack-cli 2.创建配 ...

  2. webpack4.0入门以及使用

    1. 安装webpack 先新建一个文件夹(demos),然后 npm init -y 新建一个package.json然后在当前目录执行webpack命令 webpack 模块未发现或者未找到src ...

  3. ASP.NET Core 1.0 入门——Application Startup

    var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...

  4. Omnet++ 4.0 入门实例教程

    http://blog.sina.com.cn/s/blog_8a2bb17d01018npf.html 在网上找到的一个讲解omnet++的实例, 是4.0下面实现的. 我在4.2上试了试,可以用. ...

  5. 史上最走心webpack4.0中级教程——配置之外你应该知道的事

    <webpack4.0各个击破系列>适合不满足于只会配置webpack但一时间又看不懂源码的中级读者.我没法保证这个系列是最好的,但至少能保证每一篇博文都跟那些Ctrl+C和Ctrl+V的 ...

  6. webpack4.0各个击破(4)—— Javascript & splitChunk

    目录 一. Js模块化开发 二. Js文件的一般打包需求 三. 使用webpack处理js文件 3.1 使用babel转换ES6+语法 3.2 脚本合并 3.3 公共模块识别 3.4 代码分割 3.5 ...

  7. webpack4.0各个击破(9)—— karma篇

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

  8. webpack4.0各个击破(10)—— Integration篇

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

  9. webpack4.0 实战记录

    从零配置webpack4.0 搭建React工程. 基本环境:Node(v8.1.2)+ webpack(v4.16.2) 1.在项目目录 命令窗口  执行  npm init 初始化项目,执行完后项 ...

随机推荐

  1. IDEA中Git实战

    工作中多人使用版本控制软件协作开发,常见的应用场景归纳如下: 假设小组中有两个人,组长小张,组员小袁 场景一:小张创建项目并提交到远程Git仓库 场景二:小袁从远程Git仓库上获取项目源码 场景三:小 ...

  2. css垂直居中方法(四)

    第六种方法,使用css的writing-mode属性,结合margin:auto. 参考文章:改变CSS世界纵横规则的writing-mode属性 传统的web流中,margin设置auto值的时候, ...

  3. 使用Aspectj 的配置文件方式进行aop操作

  4. show table detail

    create table #t(name varchar(255), rows bigint, reserved varchar(20),data varchar(20), index_size va ...

  5. __tostring和__invoke 方法

    首先放上代码: <?php class MagicTest{ //__tostring会在把对象转换为string的时候自动调用 public function __tostring() { r ...

  6. 什么是FastCGI, PHP-FPM

    CGI,FastCGI都是一套接口标准:是编程语言(比如php,python; python里面也有wsgi)与web服务器(比如Nginx)的通信标准(比如你跟老外交流,那么FastCGI就相当于是 ...

  7. Blender 基础 骨架 01

    Blender 基础 骨架 01 我使用的Blender版本:Blender V 2.77 前言 本讲介绍: 骨架的基本使用方式. 骨架是角色动画里面最常使用的元素,它可以准确控制一个模型的变形,尤其 ...

  8. vue 之 模板字符串

    传统的JavaScript语言,输出模板通常是这样的写的. $('#result').append( 'There are <b>' + basket.count + '</b> ...

  9. vue 之 nodejs中npm的使用

    npm是什么? 简单的说,npm就是JavaScript的包管理工具.类似Java语法中的maven,gradle,python中的pip. 安装包 我们在桌面上创建一个文件夹/01-studyNpm ...

  10. Java并发之FutureTask

    FutureTask实现了Runnable和Future接口,是一个可取消的异步任务.利用开始和取消计算的方法.查询计算是否完成的方法和获取计算结果的方法,此类提供了对 Future 的基本实现.仅在 ...