亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

webpack自動(dòng)化打包webpack-dev-server的實(shí)現(xiàn)

 更新時(shí)間:2023年07月27日 09:32:44   作者:jieyucx  
我們每次改完要打包的資源文件,和配置文件都是是輸入npx webpack命令手動(dòng)打包的,本文就來(lái)介紹一下webpack自動(dòng)化打包webpack-dev-server的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下

在前面的章節(jié)中我們每次改完要打包的資源文件,和配置文件都是是輸入npx webpack命令手動(dòng)打包的,那么有沒(méi)有什么辦法可以監(jiān)聽(tīng)到我們代碼的改動(dòng),在保存時(shí)就自動(dòng)打包呢?

答案是當(dāng)然有,不然哪些框架的腳手架是怎么實(shí)現(xiàn)保存自動(dòng)打包的呢,這就是本章要介紹的內(nèi)容,webpack-dev-server插件,自動(dòng)打包

一、什么是webpack-dev-server

Webpack Dev Server是一個(gè)基于Node.js構(gòu)建的Web服務(wù)器,它可以在本地開(kāi)發(fā)環(huán)境中啟動(dòng)一個(gè)實(shí)時(shí)的Web服務(wù)器,并且能夠自動(dòng)編譯并且刷新瀏覽器,為前端開(kāi)發(fā)提供了很大的便利。

Webpack Dev Server支持熱模塊替換(HMR),即在應(yīng)用程序運(yùn)行中更新模塊而無(wú)需刷新整個(gè)頁(yè)面,它還提供了一些其它的特性包括壓縮、編譯、轉(zhuǎn)換、代碼分離等等。Webpack Dev Server通常用來(lái)搭建本地開(kāi)發(fā)環(huán)境,而部署時(shí)則需要使用其它的Web服務(wù)器

二、在webpack中配置

1. 下載安裝

npm i webpack-dev-server -D

2. 在webpack.config.js中配置使用

const path = require("path");
module.exports = {
  entry: "./src/main.js",
  output: {
    path: path.resolve(__dirname, "dist"),
    filename: "js/main.js", // 將 js 文件輸出到 static/js 目錄中
  },
  module: {
    rules: [],
  },
  plugins: [],
  // 開(kāi)發(fā)服務(wù)器
  devServer: {
    host: "localhost", // 啟動(dòng)服務(wù)器域名
    port: "3000", // 啟動(dòng)服務(wù)器端口號(hào)
    open: true, // 是否自動(dòng)打開(kāi)瀏覽器
  },
  mode: "development",
};

這個(gè)是個(gè)服務(wù),是和webpack五大核心配置屬性同一級(jí)的,我們需要新增devServer配置對(duì)象。

完整代碼如下:

webpack.config.js

// Node.js的核心模塊,專(zhuān)門(mén)用來(lái)處理文件路徑
const path = require("path");
const ESLintWebpackPlugin = require("eslint-webpack-plugin"); // 引入 ESLint 插件
const HtmlWebpackPlugin = require("html-webpack-plugin"); // 引入 html-webpack-plugin 插件
module.exports = {
  // 入口
  // 相對(duì)路徑和絕對(duì)路徑都行
  entry: "./src/main.js",
  // 輸出
  output: {
    // path: 文件輸出目錄,必須是絕對(duì)路徑
    // path.resolve()方法返回一個(gè)絕對(duì)路徑
    // __dirname 當(dāng)前文件的文件夾絕對(duì)路徑
    path: path.resolve(__dirname, "dist"),
    // filename: js文件輸出文件名
    filename: "js/main.js",
    clean: true, // 自動(dòng)將上次打包目錄資源清空
  },
  // 加載器
  module: {
    rules: [
      {
        // 用來(lái)匹配 .css 結(jié)尾的文件
        test: /\.css$/,
        // use 數(shù)組里面 Loader 執(zhí)行順序是從右到左
        use: ["style-loader", "css-loader"],
      },
      {
        // 用來(lái)匹配.less結(jié)尾的文件
        test: /\.less$/,
        use: ["style-loader", "css-loader", "less-loader"],
      },
      {
        test: /\.s[ac]ss$/,
        use: ["style-loader", "css-loader", "sass-loader"],
      },
      {
        // 用來(lái)匹配圖片文件
        test: /\.(png|jpe?g|gif|webp)$/,
        type: "asset",
        parser: {
          dataUrlCondition: {
            maxSize: 10 * 1024, // 小于10kb的圖片會(huì)被base64處理
          },
        },
        generator: {
          // 將圖片文件輸出到 images 目錄中
          // 將圖片文件命名 [hash:8][ext][query]
          // [hash:8]: hash值取8位
          // [ext]: 使用之前的文件擴(kuò)展名
          // [query]: 添加之前的query參數(shù)
          filename: "images/[hash:8][ext][query]",
        },
      },
      {
        test: /\.(ttf|woff2?|map4|map3|avi)$/,
        type: "asset/resource", // 以文件資源的形式輸出
        generator: {
          filename: "media/[hash:8][ext][query]", // 輸出到media目錄中
        },
      },
      {
        test: /\.m?js$/, // 轉(zhuǎn)譯哪些文件
        exclude: /(node_modules|bower_components)/, // 排除哪些文件夾中的js文件不用轉(zhuǎn)譯
        // use: {
        loader: 'babel-loader',
        //   options: {
        //     presets: ['@babel/preset-env'] // 添加預(yù)設(shè),轉(zhuǎn)譯js文件
        //   }
        // }
      }
    ],
  },
  // 插件
  plugins: [
    new ESLintWebpackPlugin({
      // 指定檢查文件的根目錄
      context: path.resolve(__dirname, "src"),
    }),
    new HtmlWebpackPlugin({
        // 以 public/index.html 為模板創(chuàng)建文件
        // 新的html文件有兩個(gè)特點(diǎn):1. 內(nèi)容和源文件一致 2. 自動(dòng)引入打包生成的js等資源
        template: path.resolve(__dirname, "public/index.html"),
    }),
  ],
  // 開(kāi)發(fā)服務(wù)器
  devServer: {
    host: "localhost", // 啟動(dòng)服務(wù)器域名
    port: "8888", // 啟動(dòng)服務(wù)器端口號(hào)
    open: true, // 是否自動(dòng)打開(kāi)瀏覽器
  },
  // 模式
  mode: "development", // 開(kāi)發(fā)模式
};

3. 自動(dòng)打包命令

npx webpack serve

如上圖,執(zhí)行命令以后,webpack-dev-server會(huì)自動(dòng)在本地啟動(dòng)一個(gè)服務(wù),并為我們?cè)跒g覽器運(yùn)行打包好的資源。

4. 體驗(yàn)自動(dòng)打包

這時(shí)我們?nèi)ジ囊幌滦枰虬Y源文件,并保存看看效果更改保存前:

更改保存后:

可以看到已經(jīng)幫我們自動(dòng)打包并運(yùn)行到瀏覽器了

到此我們終于是結(jié)束了在開(kāi)發(fā)環(huán)境下手動(dòng)運(yùn)行打包后的資源文件的時(shí)代,進(jìn)一步解放雙手拉。

5. 內(nèi)存運(yùn)行

如圖,我們清空dist目錄下的所有文件,重新npx webpack serve打包

可以看到打包成功,并重新運(yùn)行到了瀏覽器,但是dist目錄下依然是空的。這就證明了一點(diǎn),webpack-dev-server是在本地內(nèi)存中遠(yuǎn)行的,這也是咱本地開(kāi)發(fā)環(huán)境需要的,至于dist目錄要如何才能出來(lái),需要配置生產(chǎn)環(huán)境,在后續(xù)會(huì)更新哦。

到此這篇關(guān)于webpack自動(dòng)化打包webpack-dev-server的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)webpack自動(dòng)化打包 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論