博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
webpack学习笔记(2)-webpack核心概念
阅读量:6253 次
发布时间:2019-06-22

本文共 4897 字,大约阅读时间需要 16 分钟。

在项目下创建一个webpack.config.js(默认,可修改)文件来配置webpack

module.exports = {    entry: '',               // 入口文件    output: {},              // 出口文件    module: {},              // 处理对应模块    plugins: [],             // 对应的插件    devServer: {},           // 开发服务器配置    mode: 'development'      // 模式配置}

以上就是webpack的正常配置模块

entry

工程资源的入口,它可以是单个文件也可以是多个文件。

Entry 类型

  • string(单个文件入口)
module.exports = {    entry: './app.js'}
  • array(多个文件入口)
module.exports = {    entry: ['./app.js','./index.js']}
  • object(多个文件入口)
module.exports = {    entry: {index,'./index.js',app,'./app.js'} //index表示独特的chunk}

context

Webpack 在寻找相对路径的文件时会以 context 为根目录,context 默认为执行启动 Webpack 时所在的当前工作目录。 如果想改变 context 的默认配置,则可以在配置文件里这样设置它:

module.exports = {  context: path.resolve(__dirname, 'app')}

Chunk 名称

Webpack 会为每个生成的 Chunk 取一个名称,Chunk 的名称和 Entry 的配置有关:

  • 如果 entry 是一个 string 或 array,就只会生成一个 Chunk,这时 Chunk 的名称是 main;
  • 如果 entry 是一个 object,就可能会出现多个 Chunk,这时 Chunk 的名称是 object 键值对里键的名称。

动态 Entry

假如项目里有多个页面需要为每个页面的入口配置一个 Entry ,但这些页面的数量可能会不断增长,则这时 Entry 的配置会受到到其他因素的影响导致不能写成静态的值。其解决方法是把 Entry 设置成一个函数去动态返回上面所说的配置,代码如下:

// 同步函数entry: () => {  return {    a:'./pages/a',    b:'./pages/b',  }};// 异步函数entry: () => {  return new Promise((resolve)=>{    resolve({       a:'./pages/a',       b:'./pages/b',    });  });};

output

这是一个配置对象,通过它我们可以对最终打包的产物进行配置。

filename

output.filename 配置输出文件的名称,为string 类型。

  • 单个文件的输出
const path = require('path');module.exports = {    entry: './app.js',    output: {        path: path.join(__dirname, 'dist'), //打包资源放置的路径,必须为绝对路径。        filename: 'bundle.js' //打包结果的文件名。    }}
  • 多个文件的输出
const path = require('path');module.exports = {    entry: {index,'./index.js',app,'./app.js'},    output: {        path: path.join(__dirname, 'dist'),        filename: '[name].min.[hash:5].js'    }}

chunkFilename

output.chunkFilename 配置无入口的 Chunk 在输出时的文件名称。 chunkFilename 和上面的 filename 非常类似,但 chunkFilename 只用于指定在运行过程中生成的 Chunk 在输出时的文件名称。 常见的会在运行时生成 Chunk 场景有在使用 CommonChunkPlugin、使用 import('path/to/module') 动态加载等时。 chunkFilename 支持和 filename 一致的内置变量。

path

output.path 配置输出文件存放在本地的目录,必须是 string 类型的绝对路径。通常通过 Node.js 的 path 模块去获取绝对路径:

path: path.resolve(__dirname, 'dist_[hash]')

publicPath

output.publicPath 配置发布到线上资源的 URL 前缀,为string 类型。 默认值是空字符串 '',即使用相对路径。

需要把构建出的资源文件上传到 CDN 服务上,以利于加快页面的打开速度。配置代码如下:

filename:'[name]_[chunkhash:8].js'publicPath: 'https://cdn.example.com/assets/'

这时发布到线上的 HTML 在引入 JavaScript 文件时就需要:

使用该配置项时要小心,稍有不慎将导致资源加载404错误。

module

module 配置如何处理模块。

配置Loaders

处理文件,Webpack 本身只能处理 JavaScript,而对于别的类型的语法则完全不认识。如果我们需要引入某一类型的模块,那么就需要通过为它添加特性类型的 loader。

rules 配置模块的读取和解析规则,通常用来配置 Loader。其类型是一个数组,数组里每一项都描述了如何去处理部分文件。

  1. 条件匹配:通过 testincludeexclude 三个配置项来命中 Loader 要应用规则的文件。
  2. 应用规则:对选中后的文件通过 use 配置项来应用 Loader,可以只应用一个 Loader 或者按照从后往前的顺序应用一组 Loader,同时还可以分别给 Loader 传入参数。
  3. 重置顺序:一组 Loader 的执行顺序默认是从右到左执行,通过 enforce 选项可以让其中一个 Loader 的执行顺序放到最前或者最后。
module: {  rules: [    {      // 命中 JavaScript 文件      test: /\.js$/,      // 用 babel-loader 转换 JavaScript 文件      // ?cacheDirectory 表示传给 babel-loader 的参数,用于缓存 babel 编译结果加快重新编译速度      use: ['babel-loader?cacheDirectory'],      // 只命中src目录里的js文件,加快 Webpack 搜索速度      include: path.resolve(__dirname, 'src')    },    {      // 命中 SCSS 文件      test: /\.scss$/,      // 使用一组 Loader 去处理 SCSS 文件。      // 处理顺序为从后到前,即先交给 sass-loader 处理,再把结果交给 css-loader 最后再给 style-loader。      use: ['style-loader', 'css-loader', 'sass-loader'],      // 排除 node_modules 目录下的文件      exclude: path.resolve(__dirname, 'node_modules'),    },    {      // 对非文本文件采用 file-loader 加载      test: /\.(gif|png|jpe?g|eot|woff|ttf|svg|pdf)$/,      use: ['file-loader'],    },  ]}

在 Loader 需要传入很多参数时,你还可以通过一个 Object 来描述,例如在上面的 babel-loader 配置中有如下代码:

use: [  {    loader:'babel-loader',    options:{      cacheDirectory:true,    },    // enforce:'post' 的含义是把该 Loader 的执行顺序放到最后    // enforce 的值还可以是 pre,代表把 Loader 的执行顺序放到最前面    enforce:'post'  },  // 省略其它 Loader]

上面的例子中 test include exclude 这三个命中文件的配置项只传入了一个字符串或正则,其实它们还都支持数组类型,使用如下:

{  test:[    /\.jsx?$/,    /\.tsx?$/  ],  //只选中当前目录  include:[    path.resolve(__dirname, 'src'),    path.resolve(__dirname, 'tests'),  ],  //排除相应目录文件  exclude:[    path.resolve(__dirname, 'node_modules'),    path.resolve(__dirname, 'bower_modules'),  ]}

常用 Loader

  • 编译相关:babel-loader、ts-loader
  • 样式相关:style-loader、css-loader、less-loader、postcss-loader
  • 文件相关:file-loader、url-loader

plugins

Plugin 用于扩展 Webpack 功能,各种各样的 Plugin 几乎让 Webpack 可以做任何构建相关的事情。

  • 参与打包整个过程
  • 打包优化和压缩
  • 配置编译时的变量
  • 极其灵活

Plugin 的配置很简单,plugins 配置项接受一个数组,数组里每一项都是一个要使用的 Plugin 的实例,Plugin 需要的参数通过构造函数传入。

const CommonsChunkPlugin = require('webpack/lib/optimize/CommonsChunkPlugin');module.exports = {  plugins: [    // 所有页面都会用到的公共代码提取到 common 代码块中    new CommonsChunkPlugin({      name: 'common',      chunks: ['a', 'b']    }),  ]};

常用 Plugins

  • 优化相关
    CommonsChunkPlugin
    UglifyjsWebpackPlugin
  • 功能相关
    ExtractTextWebpackPlugin
    HtmlWebpackPlugin
    HotModuleReplacementPlugin
    CopyWebpackPlugin

其他名词

Chunk

相当于代码块

Bundle

打包后的一捆代码

Module

模块

转载地址:http://hzfsa.baihongyu.com/

你可能感兴趣的文章
Matlab基本函数-conj函数
查看>>
linux常用命令 3
查看>>
SharePoint 2013 托管导航 无法被开启的解决办法
查看>>
初识Java Servlet
查看>>
Test1
查看>>
JS图片切换代码合集
查看>>
Aundit使用记录文档
查看>>
原型 、原型链和对象是怎么实现继承的
查看>>
layui中select切换数据_layui 下拉框 动态获取数据
查看>>
佳能hdr_内置HDR功能 佳能5D3特色拍摄功能解析
查看>>
matlab和python转换_将MATLAB代码转换为Python:Python类型和操作顺序
查看>>
jmeter3000用户压测_jmeter集群压测搭建
查看>>
转子接地保护原理_发变组保护动作逻辑
查看>>
hive中groupby优化_面试必备技能-HiveSQL优化
查看>>
uni 页面加载完毕_HTML页面生命周期
查看>>
c语言机票座位预定系统_趁东京奥运!日航要免费送5万张国内机票!给非日本居民...
查看>>
创业冲突的五种解决方法是_冲突管理的五种策略
查看>>
lsmw中文显示乱码_中文注释不能在keil 4/5中正常显示——都是方框或乱码?
查看>>
hcg值小于0.1_【原理】JavaScript 中 0.1 + 0.2 为什么不等于 0.3?
查看>>
springboot的jsp应该放在哪_健身小白用2个月亲身经历告诉你小白去健身房,应该做到哪几点...
查看>>