成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

webpack4 系列教程(十五):開發(fā)模式與webpack-dev-server

zengdongbao / 2936人閱讀

摘要:作者按因?yàn)榻坛趟緢D片使用的是倉(cāng)庫(kù)圖片,網(wǎng)速過(guò)慢的朋友請(qǐng)移步系列教程十五開發(fā)模式與原文地址。而開發(fā)模式就是指定為。在非開發(fā)模式下,需要關(guān)閉此選項(xiàng),以減小打包體積。在單頁(yè)應(yīng)用中,任何響應(yīng)直接被替代為。

作者按:因?yàn)榻坛趟緢D片使用的是 github 倉(cāng)庫(kù)圖片,網(wǎng)速過(guò)慢的朋友請(qǐng)移步《webpack4 系列教程(十五):開發(fā)模式與 webpack-dev-server》原文地址。更歡迎來(lái)我的小站看更多原創(chuàng)內(nèi)容:godbmw.com,進(jìn)行“姿勢(shì)”交流 ?(^?^*)
0. 課程介紹和資料

>>>本節(jié)課源碼

>>>所有課程源碼

本節(jié)課的代碼目錄如下:

本節(jié)課用的 plugin 和 loader 的配置文件package.json如下:

{
  "scripts": {
    "dev": "webpack-dev-server --open"
  },
  "devDependencies": {
    "clean-webpack-plugin": "^0.1.19",
    "html-webpack-plugin": "^3.2.0",
    "jquery": "^3.3.1",
    "webpack": "^4.16.1",
    "webpack-cli": "^3.1.0",
    "webpack-dev-server": "^3.1.4"
  }
}
1. 為什么需要開發(fā)模式?

在之前的課程中,我們都沒(méi)有指定參數(shù)mode。但是執(zhí)行webpack進(jìn)行打包的時(shí)候,自動(dòng)設(shè)置為production,但是控制臺(tái)會(huì)爆出warning的提示。而開發(fā)模式就是指定modedevelopment。

在開發(fā)模式下,我們需要對(duì)代碼進(jìn)行調(diào)試。對(duì)應(yīng)的配置就是:devtool設(shè)置為source-map。在非開發(fā)模式下,需要關(guān)閉此選項(xiàng),以減小打包體積。

在開發(fā)模式下,還需要熱重載、路由重定向、掛代理等功能,webpack4已經(jīng)提供了devServer選項(xiàng),啟動(dòng)一個(gè)本地服務(wù)器,讓開發(fā)者使用這些功能。

2. 如何使用開發(fā)模式?

根據(jù)文章開頭的package.json的配置,只需要在命令行輸入:npm run dev即可啟動(dòng)開發(fā)者模式。

啟動(dòng)效果如下圖所示:

雖然控制臺(tái)輸出了打包信息(假設(shè)我們已經(jīng)配置了熱重載),但是磁盤上并沒(méi)有創(chuàng)建/dist/文件夾和打包文件。控制臺(tái)的打包文件的相關(guān)內(nèi)容是存儲(chǔ)在內(nèi)存之中的。

3. 編寫一些需要的文件

首先,編寫一下入口的 html 文件:





  
  
  
  Document


  This is Index html

然后,按照項(xiàng)目目錄,簡(jiǎn)單封裝下/vendor/下的三個(gè) js 文件,以方便app.js調(diào)用:

// minus.js
module.exports = function(a, b) {
  return a - b;
};

// multi.js
define(function(require, factory) {
  "use strict";
  return function(a, b) {
    return a * b;
  };
});

// sum.js
export default function(a, b) {
  console.log("I am sum.js");
  return a + b;
}

好了,準(zhǔn)備進(jìn)入正題。

4. 編寫 webpack 配置文件 4.1 配置代碼

由于配置內(nèi)容有點(diǎn)多,所以放代碼,再放講解。

webpack.config.js配置如下所示:

const webpack = require("webpack");
const HtmlWebpackPlugin = require("html-webpack-plugin");

const path = require("path");

module.exports = {
  entry: {
    app: "./app.js"
  },
  output: {
    publicPath: "/",
    path: path.resolve(__dirname, "dist"),
    filename: "[name]-[hash:5].bundle.js",
    chunkFilename: "[name]-[hash:5].chunk.js"
  },
  mode: "development", // 開發(fā)模式
  devtool: "source-map", // 開啟調(diào)試
  devServer: {
    contentBase: path.join(__dirname, "dist"),
    port: 8000, // 本地服務(wù)器端口號(hào)
    hot: true, // 熱重載
    overlay: true, // 如果代碼出錯(cuò),會(huì)在瀏覽器頁(yè)面彈出“浮動(dòng)層”。類似于 vue-cli 等腳手架
    proxy: {
      // 跨域代理轉(zhuǎn)發(fā)
      "/comments": {
        target: "https://m.weibo.cn",
        changeOrigin: true,
        logLevel: "debug",
        headers: {
          Cookie: ""
        }
      }
    },
    historyApiFallback: {
      // HTML5 history模式
      rewrites: [{ from: /.*/, to: "/index.html" }]
    }
  },
  plugins: [
    new HtmlWebpackPlugin({
      filename: "index.html",
      template: "./index.html",
      chunks: ["app"]
    }),
    new webpack.HotModuleReplacementPlugin(),
    new webpack.NamedModulesPlugin(),
    new webpack.ProvidePlugin({
      $: "jquery"
    })
  ]
};
4.2 模塊熱更新

模塊熱更新需要HotModuleReplacementPluginNamedModulesPlugin這兩個(gè)插件,并且順序不能錯(cuò)。并且指定devServer.hottrue。

有了這兩個(gè)插件,在項(xiàng)目的 js 代碼中可以針對(duì)偵測(cè)到變更的文件并且做出相關(guān)處理。

比如,我們啟動(dòng)開發(fā)模式后,修改了vendor/sum.js這個(gè)文件,此時(shí),需要在瀏覽器的控制臺(tái)打印一些信息。那么,app.js中就可以這么寫:

if (module.hot) {
  // 檢測(cè)是否有模塊熱更新
  module.hot.accept("./vendor/sum.js", function() {
    // 針對(duì)被更新的模塊, 進(jìn)行進(jìn)一步操作
    console.log("/vendor/sum.js is changed");
  });
}

每當(dāng)sum.js被修改后,都可以自動(dòng)執(zhí)行回調(diào)函數(shù)。

4.3 跨域代理

隨著前后端分離開發(fā)的普及,跨域請(qǐng)求變得越來(lái)越常見(jiàn)。為了快速開發(fā),可以利用devServer.proxy做一個(gè)代理轉(zhuǎn)發(fā),來(lái)繞過(guò)瀏覽器的跨域限制。

按照前面的配置文件,如果想調(diào)用微博的一個(gè)接口:https://m.weibo.cn/comments/hotflow。只需要在代碼中對(duì)/comments/hotflow進(jìn)行請(qǐng)求即可:

$.get(
  "/comments/hotflow",
  {
    id: "4263554020904293",
    mid: "4263554020904293",
    max_id_type: "0"
  },
  function(data) {
    console.log(data);
  }
);
4.4 HTML5--History

當(dāng)項(xiàng)目使用HTML5 History API 時(shí),任意的 404 響應(yīng)都可能需要被替代為 index.html。

在 SPA(單頁(yè)應(yīng)用)中,任何響應(yīng)直接被替代為index.html

在 vuejs 官方的腳手架vue-cli中,開發(fā)模式下配置如下:

// ...
historyApiFallback: {
  rewrites: [{ from: /.*/, to: "/index.html" }];
}
// ...
5. 編寫入口文件

最后,在前面所有的基礎(chǔ)上,讓我們來(lái)編寫下入口文件app.js

import sum from "./vendor/sum";
console.log("sum(1, 2) = ", sum(1, 2));
var minus = require("./vendor/minus");
console.log("minus(1, 2) = ", minus(1, 2));
require(["./vendor/multi"], function(multi) {
  console.log("multi(1, 2) = ", multi(1, 2));
});

$.get(
  "/comments/hotflow",
  {
    id: "4263554020904293",
    mid: "4263554020904293",
    max_id_type: "0"
  },
  function(data) {
    console.log(data);
  }
);

if (module.hot) {
  // 檢測(cè)是否有模塊熱更新
  module.hot.accept("./vendor/sum.js", function() {
    // 針對(duì)被更新的模塊, 進(jìn)行進(jìn)一步操作
    console.log("/vendor/sum.js is changed");
  });
}
6. 效果檢測(cè)

在命令行鍵入:npm run dev開啟服務(wù)器后,會(huì)自動(dòng)打開瀏覽器。如下圖所示:

打開控制臺(tái),可以看到代碼都正常運(yùn)行沒(méi)有出錯(cuò)。除此之外,由于開啟了source-map,所以可以定位代碼位置(下圖綠框內(nèi)):

7. 參考資料

dev-server 文檔: https://www.webpackjs.com/configuration/dev-server/

開發(fā)模式 文檔:https://www.webpackjs.com/guides/development/

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/98554.html

相關(guān)文章

  • webpack-demos:全網(wǎng)最貼心webpack系列教程和配套代碼

    摘要:全網(wǎng)最貼心系列教程和配套代碼歡迎關(guān)注個(gè)人技術(shù)博客。所以我花費(fèi)了個(gè)多月整理了這份教程,一共分成節(jié),每節(jié)都有講解,并且準(zhǔn)備了配套代碼。奈何深感水平不夠,只有一腔熱情,所以直接開放了教程和源碼。 webpack-demos:全網(wǎng)最貼心 webpack 系列教程和配套代碼 歡迎關(guān)注個(gè)人技術(shù)博客:godbmw.com。每周 1 篇原創(chuàng)技術(shù)分享!開源教程(webpack、設(shè)計(jì)模式)、面試刷題(偏前...

    LMou 評(píng)論0 收藏0
  • webpack4 系列教程: 前言

    摘要:課程地址全部課程地址立即進(jìn)入課程源碼目錄截至按照知識(shí)點(diǎn),目錄分成了個(gè)文件夾之后還會(huì)持續(xù)更新。個(gè)人網(wǎng)站原文鏈接系列教程前言 本文檔已經(jīng)過(guò)時(shí),最近內(nèi)容請(qǐng)看:https://godbmw.com/passage/76。一共16節(jié)課程和代碼。謝謝支持。 1. 什么是webpack? 前端目前最主流的javascript打包工具,在它的幫助下,開發(fā)者可以輕松地實(shí)現(xiàn)加密代碼、多平臺(tái)兼容。而最重要的...

    DevWiki 評(píng)論0 收藏0
  • webpack4詳細(xì)教程,從無(wú)到有搭建react腳手架(一)

    摘要:是一個(gè)現(xiàn)代應(yīng)用程序的靜態(tài)模塊打包器,前端模塊化的基礎(chǔ)。作為一個(gè)前端工程師切圖仔,非常有必要學(xué)習(xí)。官網(wǎng)的文檔非常的棒,中文文檔也非常給力,可以媲美的文檔。建議先看概念篇章,再看指南,然后看和配置總覽。 webpack 是一個(gè)現(xiàn)代 JavaScript 應(yīng)用程序的靜態(tài)模塊打包器,前端模塊化的基礎(chǔ)。作為一個(gè)前端工程師(切圖仔),非常有必要學(xué)習(xí)。 showImg(https://segment...

    zhkai 評(píng)論0 收藏0
  • webpack4系列教程(九):開發(fā)環(huán)境和生產(chǎn)環(huán)境

    摘要:它允許在運(yùn)行時(shí)更新各種模塊,而無(wú)需進(jìn)行完全刷新。構(gòu)建生產(chǎn)環(huán)境開發(fā)環(huán)境和生產(chǎn)環(huán)境的構(gòu)建目標(biāo)差異很大。在開發(fā)環(huán)境中,我們需要具有強(qiáng)大的具有實(shí)時(shí)重新加載或熱模塊替換能力的和。 1. 構(gòu)建開發(fā)環(huán)境 如果你一直跟隨我前面的博文,那么你對(duì)webpack的基礎(chǔ)知識(shí)已經(jīng)有比較深刻的理解了。之前,我們一直執(zhí)行著: npm run build 來(lái)打包編譯輸出我們的代碼,本文我們來(lái)看看如何構(gòu)建一個(gè)開發(fā)環(huán)境,...

    姘存按 評(píng)論0 收藏0
  • 從零開始的Webpack4教程

    摘要:插件則可以用于執(zhí)行范圍更廣的任務(wù)。插件的范圍包括,從打包優(yōu)化和壓縮,一直到重新定義環(huán)境中的變量等。插件的使用一般是在的配置信息選項(xiàng)中指定。到這里基本配置已經(jīng)告一段落了,所有配置我已經(jīng)放在倉(cāng)庫(kù)中第二期優(yōu)化教程已出歡迎關(guān)注和提問(wèn) 1、了解Webpack相關(guān) 什么是webpack Webpack是一個(gè)模塊打包器(bundler)。 在Webpack看來(lái), 前端的所有資源文件(js/js...

    ShevaKuilin 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<