webpack5开发服务器与自动化

Posted 天界程序员

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了webpack5开发服务器与自动化相关的知识,希望对你有一定的参考价值。

每次写完代码都需要手动输入指令才能编译代码,太麻烦了,我们希望一切自动化


1. 安装并配置webpack开发服务

  • 安装所需依赖
npm i webpack-dev-server -D
  • 开启服务器配置

文件名:webpack.config.js

module.exports = 
  // ...
  // 开发服务器
  devServer: 
    host: "localhost", // 启动服务器域名
    port: "3000", // 启动服务器端口号
    open: true, // 是否自动打开浏览器
  ,
  mode: "development",
;
  • 运行服务器
npx webpack serve

并且当你使用开发服务器时,所有代码都会在内存中编译打包,并不会输出到 dist 目录下。

开发时我们只关心代码能运行,有效果即可,至于代码被编译成什么样子,我们并不需要知道。


2. 关于修改输出资源的名称和路径问题

如果你想你的js打包输出在一个指定的目录可以在output对象里面进行配置:

文件名:webpack.config.js

const path = require("path");

module.exports = 
  entry: "./src/main.js",
  output: 
    path: path.resolve(__dirname, "dist"),
    filename: "static/js/main.js", // 将 js 文件输出到 static/js 目录中
  ,
    // ...

如果你想你的图片资源也输出在一个指定目录可以这样配置:

文件名:webpack.config.js

module.exports = 
  entry: "./src/main.js",
  output: 
    path: path.resolve(__dirname, "dist"),
    filename: "static/js/main.js", // 将 js 文件输出到 static/js 目录中
  ,
  module: 
    rules: [
		// ...
      
        test: /\\.(png|jpe?g|gif|webp)$/,
        type: "asset",
        parser: 
          dataUrlCondition: 
            maxSize: 10 * 1024, // 小于10kb的图片会被base64处理
          ,
        ,
        generator: 
          // 将图片文件输出到 static/imgs 目录中
          // 将图片文件命名 [hash:8][ext][query]
          // [hash:8]: hash值取8位
          // [ext]: 使用之前的文件扩展名
          // [query]: 添加之前的query参数
          filename: "static/imgs/[hash:8][ext][query]",
        ,
      ,
    ],
  ,
  plugins: [],
  mode: "development",
;

运行webpack

npx webpack

你可以看到对应文件的输出目录。


3. 关于自动清空上一次的打包资源

  • 清空所有output生成的目录
module.exports = 
  //...
  output: 
    clean: true, // 在生成文件之前清空 output 目录
  ,
;
  • 打印而不是删除应该移除的静态资源
module.exports = 
  //...
  output: 
    clean: 
      dry: true, // 打印而不是删除应该移除的静态资源
    ,
  ,
;
  • 保留 指定目录下的静态资源
module.exports = 
  //...
  output: 
    clean: 
      keep: /ignored\\/dir\\//, // 保留 'ignored/dir' 下的静态资源
    ,
  ,
;

// 或者

module.exports = 
  //...
  output: 
    clean: 
      keep(asset) 
        return asset.includes('ignored/dir');
      ,
    ,
  ,
;
  • 对应你需要的情况运行webpack观察结果
npx webpack

观察dist目录的变化情况。

以上是关于webpack5开发服务器与自动化的主要内容,如果未能解决你的问题,请参考以下文章

Webpack5之px自动转换成rem

Webpack5之px自动转换成rem

webpack5 开发模式与生产模式

webpack5处理js资源

webpack5处理其他资源

Node.js + Webpack5 后端开发