webpack 基础

作者: 前端开发小匠 | 来源:发表于2018-08-04 15:53 被阅读205次

现在前端的打包工具很多而webpack是前端用的非常多的一个打包工具,最近准备开始从零重新认识的webpack, 理一理关于webpack那些事儿。学习之前肯定得先安装咯,但是安装后运行也是遇到了一些坑, 下面简单记录下。如果你使用的是webpack1/2/3可能就没有下面的问题。

  1. webpack-cli 不存在问题

    安装依赖模块, 使用npm i webpack后然后运行总是报错总提示下面的错误:

    webpack One CLI for webpack must be installed. These are recommended choices, delivered as separate.

    后来查了一下原来默认安装的是webpack4,webpack4中还需要安装webpack-cli,同时也需要在全局安装webpack webpack-cli模块。

    # 全局安装
    npm i webpack webpack-cli  -g
    # 作为项目依赖安装
    npm i webpack webpack-cli  --save-dev
    
  2. 重复安装webpack-cliwebpack-command问题

    You have installed webpack-cli and webpack-command together. To work with the "webpack" command you need only one CLI package, please remove one of them or use them directly via their binary.

    这个错误说明您已经安装了webpack-cliwebpack-command。要使用“webpack”命令,您只需要一个CLI包,请删除其中一个或直接通过二进制文件使用它们。

    npm remove webpack-cli 或者 npm remove webpack-command 不行的话试试 npm remove --global webpack-cli

  3. 运行过程中有时候还有有个warning, 需呀添加--mode设置。在配置运行脚本的时候添加--mode=development--mode=production即。

    // package.json
    {
      "scripts": {
        "dev": "webpack --mode=development",
        "build": "webpack --mode=production",
      },
    }
    

四个核心概念

  • entry
  • output
  • loader
  • plugin

示例

entry的几种写法

module.exports = {
  entry: './src/app.js',
  // ...
}

module.exports = {
  entry: {
    main: './src/app.js'
  },
  // ...
}

// 多页面
module.exports = {
  entry: {
    pageOne: './src/pageOne/index.js',
    pageTwo: './src/pageTwo/index.js',
    pageThree: './src/pageThree/index.js'
  },
  // ...
}

// vendor
module.exports = {
  entry: {
    app: './src/app.js',
    vendor: ['underscore']
  },
  // ...
}

vendor设置在webpack3 webpack4中设置不同

参考实例3实例4

extract-text-webpack-plugin

参考

实例styles-webpack3

  1. npm scripts 使用指南
  2. Webpack 4 不完全迁移指北

相关文章

网友评论

本文标题:webpack 基础

本文链接:https://www.haomeiwen.com/subject/hksmvftx.html