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

資訊專欄INFORMATION COLUMN

從零開始的Webpack4教程

ShevaKuilin / 1883人閱讀

摘要:插件則可以用于執(zhí)行范圍更廣的任務(wù)。插件的范圍包括,從打包優(yōu)化和壓縮,一直到重新定義環(huán)境中的變量等。插件的使用一般是在的配置信息選項(xiàng)中指定。到這里基本配置已經(jīng)告一段落了,所有配置我已經(jīng)放在倉(cāng)庫(kù)中第二期優(yōu)化教程已出歡迎關(guān)注和提問

1、了解Webpack相關(guān)

什么是webpack

Webpack是一個(gè)模塊打包器(bundler)。

在Webpack看來(lái), 前端的所有資源文件(js/json/css/img/less/...)都會(huì)作為模塊處理

它將根據(jù)模塊的依賴關(guān)系進(jìn)行靜態(tài)分析,生成對(duì)應(yīng)的靜態(tài)資源

五個(gè)核心概念

Entry:入口起點(diǎn)(entry point)指示 webpack 應(yīng)該使用哪個(gè)模塊,來(lái)作為構(gòu)建其內(nèi)部依賴圖的開始。

Output:output 屬性告訴 webpack 在哪里輸出它所創(chuàng)建的 bundles,以及如何命名這些文件,默認(rèn)值為 ./dist。

Loader:loader 讓 webpack 能夠去處理那些非 JavaScript 文件(webpack 自身只能解析 JavaScript)。

Plugins:插件則可以用于執(zhí)行范圍更廣的任務(wù)。插件的范圍包括,從打包優(yōu)化和壓縮,一直到重新定義環(huán)境中的變量等。

Mode:模式,有生產(chǎn)模式production和開發(fā)模式development

理解Loader

Webpack 本身只能加載JS/JSON模塊,如果要加載其他類型的文件(模塊),就需要使用對(duì)應(yīng)的loader 進(jìn)行轉(zhuǎn)換/加載

Loader 本身也是運(yùn)行在 node.js 環(huán)境中的 JavaScript 模塊

它本身是一個(gè)函數(shù),接受源文件作為參數(shù),返回轉(zhuǎn)換的結(jié)果

loader 一般以 xxx-loader 的方式命名,xxx 代表了這個(gè) loader 要做的轉(zhuǎn)換功能,比如 json-loader。

理解Plugins

插件可以完成一些loader不能完成的功能。

插件的使用一般是在 webpack 的配置信息 plugins 選項(xiàng)中指定。

配置文件(默認(rèn))

webpack.config.js : 是一個(gè)node模塊,返回一個(gè) json 格式的配置信息對(duì)象

2、開啟項(xiàng)目

初始化項(xiàng)目:

生成package.json文件

{
  "name": "webpack_test",
  "version": "1.0.0"
} 

安裝webpack

npm install webpack webpack-cli -g //全局安裝

npm install webpack webpack-cli -D //本地安裝

3、編譯打包應(yīng)用

創(chuàng)建js文件

src/js/app.js

src/js/module1.js

src/js/module2.js

src/js/module3.js

創(chuàng)建json文件

src/json/data.json

創(chuàng)建主頁(yè)面:

src/index.html

運(yùn)行指令

開發(fā)配置指令:webpack src/js/app.js -o dist/js/app.js --mode=development

功能: webpack能夠編譯打包js和json文件,并且能將es6的模塊化語(yǔ)法轉(zhuǎn)換成瀏覽器能識(shí)別的語(yǔ)法

生產(chǎn)配置指令:webpack src/js/app.js -o dist/js/app.js --mode=production

功能: 在開發(fā)配置功能上加上一個(gè)壓縮代碼

結(jié)論:

webpack能夠編譯打包js和json文件

能將es6的模塊化語(yǔ)法轉(zhuǎn)換成瀏覽器能識(shí)別的語(yǔ)法

能壓縮代碼

缺點(diǎn):

不能編譯打包c(diǎn)ss、img等文件

不能將js的es6基本語(yǔ)法轉(zhuǎn)化為es5以下語(yǔ)法

改善:使用webpack配置文件解決,自定義功能

4、使用webpack配置文件

目的:在項(xiàng)目根目錄定義配置文件,通過(guò)自定義配置文件,還原以上功能

文件名稱:webpack.config.js

文件內(nèi)容:

const {resolve} = require("path"); //node內(nèi)置核心模塊,用來(lái)設(shè)置路徑。
module.exports = {
  entry: "./src/js/app.js",   // 入口文件
  output: {                     // 輸出配置
    filename: "./js/bundle.js",      // 輸出文件名
    path: resolve(__dirname, "dist")   //輸出文件路徑配置
  },
  mode: "development"   //開發(fā)環(huán)境(二選一)
  mode: "production"   //生產(chǎn)環(huán)境(二選一)
};

運(yùn)行指令: webpack

5、js語(yǔ)法檢查

安裝loader

npm install eslint-loader eslint --save-dev

配置loader

module: {
  rules: [
    {
      test: /.js$/,  //只檢測(cè)js文件
      exclude: /node_modules/,  //排除node_modules文件夾
      enforce: "pre",  //提前加載使用
      use: { //使用eslint-loader解析
        loader: "eslint-loader" 
      }
    }        
  ]
}

修改package.json(需要?jiǎng)h除注釋才能生效)

"eslintConfig": {   //eslint配置
  "parserOptions": {  
    "ecmaVersion": 8,  // es8
    "sourceType": "module", //  ECMAScript 模塊
  }
}

運(yùn)行指令:webpack

6、js語(yǔ)法轉(zhuǎn)換

安裝loader

npm install babel-loader @babel/core @babel/preset-env --save-dev

配置loader

module: {
  rules: [
    {
      oneOf: [  //數(shù)組中的配置只有一個(gè)能夠生效, 后面的配置都會(huì)放在當(dāng)前數(shù)組中
        {
          test: /.js$/,
          exclude: /node_modules/,
          use: {
            loader: "babel-loader",
            options: {
              presets: ["@babel/preset-env"]
            }
          }
        }
      ]
    }
  ]
}

運(yùn)行指令:webpack

7、打包less資源

創(chuàng)建less文件

src/less/test1.less

src/less/test2.less

入口app.js文件

引入less資源

安裝loader

npm install css-loader style-loader less-loader less --save-dev

配置loader

oneOf: [
  {
    test: /.less$/,
    use: [{
      loader: "style-loader"
    }, {
      loader: "css-loader" 
    }, {
      loader: "less-loader" 
    }]
  }
]

運(yùn)行指令:webpack

在index.html中引入打包生成的dist/js/bundle.js文件,觀察效果

8、打包樣式文件中的圖片資源

添加2張圖片:

小圖, 小于8kb: src/images/1.png

大圖, 大于8kb: src/images/2.jpg

在less文件中通過(guò)背景圖的方式引入圖片

安裝loader

npm install file-loader url-loader --save-dev

補(bǔ)充:url-loader是對(duì)象file-loader的上層封裝,使用時(shí)需配合file-loader使用。

配置loader

{
  test: /.(png|jpg|gif|svg)$/,
  use: [
    {
      loader: "url-loader",
      options: {
        outputPath: "images/",   //在output基礎(chǔ)上,修改輸出圖片文件的位置
        publicPath: "../dist/images/",  //修改背景圖引入url的路徑
        limit: 8 * 1024,  // 8kb大小以下的圖片文件都用base64處理
        name: "[hash:8].[ext]"  // hash值為7位,ext自動(dòng)補(bǔ)全文件擴(kuò)展名
      }
    }
  ]
}

運(yùn)行指令:webpack

在index.html中引入打包生成的dist/js/bundle.js文件,觀察效果

9、打包html文件

添加html文件

src/index.html

注意不要在html中引入任何css和js文件

安裝插件Plugins

npm install clean-webpack-plugin --save-dev

在webpack.config.js中引入插件(插件都需要手動(dòng)引入,而loader會(huì)自動(dòng)加載)

const CleanWebpackPlugin = require("clean-webpack-plugin")

配置插件Plugins

plugins: [
  new HtmlWebpackPlugin({
    template: "./src/index.html"
  }),
]

運(yùn)行指令:webpack

10、打包html中圖片資源

添加圖片

在src/index.html添加兩個(gè)img標(biāo)簽

安裝loader

npm install html-loader --save-dev

修改entry

entry: ["./src/js/app.js", "./src/index.html"]

配置loader

{
  test: /.(html)$/,
  use: {
    loader: "html-loader"
  }
}

運(yùn)行指令:webpack

11、打包其他資源

添加字體文件

src/media/iconfont.eot

src/media/iconfont.svg

src/media/iconfont.ttf

src/media/iconfont.woff

src/media/iconfont.woff2

修改樣式

@font-face {
  font-family: "iconfont";
  src: url("../media/iconfont.eot");
  src: url("../media/iconfont.eot?#iefix") format("embedded-opentype"),
  url("../media/iconfont.woff2") format("woff2"),
  url("../media/iconfont.woff") format("woff"),
  url("../media/iconfont.ttf") format("truetype"),
  url("../media/iconfont.svg#iconfont") format("svg");
}

.iconfont {
  font-family: "iconfont" !important;
  font-size: 16px;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

修改html,添加字體

配置loader

{
  loader: "file-loader",
  exclude: [/.js$/, /.html$/, /.json$/],
  options: {
    outputPath: "media/",
    publicPath: "../dist/media/",
    name: "[hash:8].[ext]",
  },
}

運(yùn)行指令:webpack

12、自動(dòng)編譯打包運(yùn)行

安裝loader

npm install webpack-dev-server --save-dev

引入webpack

const webpack = require("webpack");

修改webpack配置對(duì)象(注意不是loader中)

devtool: "inline-source-map",  // 將編譯后的代碼映射回原始源代碼,更容易地追蹤錯(cuò)誤和警告
devServer: {
  contentBase: "./dist",  //項(xiàng)目根路徑
  hot: true,  //開啟熱模替換功能
  open: true  //自動(dòng)打開瀏覽器
},
plugins: [
  new webpack.NamedModulesPlugin(),
  new webpack.HotModuleReplacementPlugin()
]

修改loader部分配置

因?yàn)闃?gòu)建工具以dist為根目錄,不用再找dist了

publicPath: "../dist/images/" --> publicPath: "images/"

publicPath: "../dist/media/" --> publicPath: "media/"

修改package.json中scripts指令

"start": "webpack-dev-server",

"dev": "webpack-dev-server"

運(yùn)行指令:npm start / npm run dev

以上就是webpack開發(fā)環(huán)境的配置,可以在內(nèi)存中自動(dòng)打包所有類型文件并有自動(dòng)編譯運(yùn)行、熱更新等功能。
13、準(zhǔn)備生產(chǎn)環(huán)境

創(chuàng)建文件夾config,將webpack.config.js復(fù)制兩份

webpack.dev.js

webpack.prod.js

修改webpack.prod.js配置,刪除webpack-dev-server配置

module.exports = {
  output: {
    filename: "js/[name].[hash:8].js",   //添加了hash值, 實(shí)現(xiàn)靜態(tài)資源的長(zhǎng)期緩存
    publicPath: "/"  //所有輸出資源公共路徑
  },
  module: {  //loader其他沒有變化,只放了變化部分,只有需要修改路徑部分改了
    rules: [
      {
        oneOf: [
          {
            test: /.(png|jpg|gif|svg)$/,
            use: [
              {
                loader: "url-loader",
                options: {
                  limit: 8 * 1024,  // 8kb大小以下的圖片文件都用base64處理
                  name: "images/[name].[hash:8].[ext]"
                }
              }
            ]
          },
          {
            loader: "file-loader",
            exclude: [/.js$/, /.html$/, /.json$/],
            options: {
              name: "media/[name].[hash:8].[ext]",
            },
          }
        ]
      }
    ]
  },
  mode: "production",  //修改為生產(chǎn)環(huán)境
}

修改package.json的指令

"start": "webpack-dev-server --config ./config/webpack.dev.js"

"dev": "webpack-dev-server --config ./config/webpack.dev.js"

"build": "webpack --config ./config/webpack.prod.js"

開發(fā)環(huán)境指令

npm start

npm run dev

生產(chǎn)環(huán)境指令

npm run build

注意: 生產(chǎn)環(huán)境代碼需要部署到服務(wù)器上才能運(yùn)行

npm i serve -g

serve -s dist

14、清除打包文件目錄

安裝插件

npm install clean-webpack-plugin --save-dev

引入插件

const CleanWebpackPlugin = require("clean-webpack-plugin");

配置插件

new CleanWebpackPlugin()

運(yùn)行指令:npm run build

15、提取css成多帶帶文件

安裝插件

npm install mini-css-extract-plugin --save-dev

引入插件

const MiniCssExtractPlugin = require("mini-css-extract-plugin");

配置loader

{
  test: /.less$/,
  use: [
    MiniCssExtractPlugin.loader,
    "css-loader",
    "less-loader",
  ]
}

配置插件

new MiniCssExtractPlugin({
  filename: "css/[name].[hash:8].css",
  chunkFilename: "css/[id].[hash:8].css"
})

運(yùn)行指令

npm run build

serve -s dist

16、添加css兼容

安裝loader

npm install postcss-loader autoprefixer --save-dev

配置loader

{
  test: /.less$/,
  use: [
    MiniCssExtractPlugin.loader,
    "css-loader",
    "postcss-loader",
    "less-loader",
  ]
}

在項(xiàng)目根目錄添加postcss配置文件:postcss.config.js

module.exports = {
  "plugins": {
    "autoprefixer": {
      "browsers": [
        "ie >= 8",
        "ff >= 30",
        "chrome >= 34",
        "safari >= 8",
        "opera >= 23"
      ]
    }
  }
}

運(yùn)行指令:

npm run build

serve -s dist

17、壓縮css

安裝插件

npm install optimize-css-assets-webpack-plugin --save-dev

引入插件

const OptimizeCssAssetsPlugin = require("optimize-css-assets-webpack-plugin");

配置插件

new OptimizeCssAssetsPlugin({
  cssProcessorPluginOptions: {
    preset: ["default", { discardComments: { removeAll: true } }],
  },
})

運(yùn)行指令:

npm run build

serve -s dist

18、圖片壓縮

安裝loader

npm install img-loader imagemin-gifsicle imagemin-mozjpeg imagemin-pngquant imagemin-svgo imagemin --save-dev

配置loader

{
  test: /.(png|jpg|gif|svg)$/,
  use: [
    {
      loader: "url-loader",
      options: {
        limit: 8 * 1024,  // 8kb大小以下的圖片文件都用base64處理
        name: "images/[name].[hash:8].[ext]"
      }
    },
    {
      loader: "img-loader",
      options: {
        plugins: [
          require("imagemin-gifsicle")({
            interlaced: false
          }),
          require("imagemin-mozjpeg")({
            progressive: true,
            arithmetic: false
          }),
          require("imagemin-pngquant")({
            floyd: 0.5,
            speed: 2
          }),
          require("imagemin-svgo")({
            plugins: [
              { removeTitle: true },
              { convertPathData: false }
            ]
          })
        ]
      }
    }
  ]
}

運(yùn)行指令:

npm run build

serve -s dist

19、壓縮html

修改插件配置

new HtmlWebpackPlugin({
  template: "./src/index.html",
  minify: {
    removeComments: true,
    collapseWhitespace: true,
    removeRedundantAttributes: true,
    useShortDoctype: true,
    removeEmptyAttributes: true,
    removeStyleLinkTypeAttributes: true,
    keepClosingSlash: true,
    minifyJS: true,
    minifyCSS: true,
    minifyURLs: true,
  }
})

運(yùn)行指令:

npm run build

serve -s dist

以上就是webpack生產(chǎn)環(huán)境的配置,可以生成打包后的文件。

到這里基本配置已經(jīng)告一段落了,所有配置我已經(jīng)放在 倉(cāng)庫(kù) 中

第二期 Webpack4優(yōu)化教程 已出~ 歡迎關(guān)注和提問~

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

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

相關(guān)文章

  • 學(xué)習(xí)從零開始搭建React腳手架

    摘要:寫在前面準(zhǔn)備學(xué)習(xí)一下和相關(guān)的東西,官方的腳手架看起來(lái)太繁瑣,所以打算自己來(lái)搭建一個(gè),參考了這個(gè)文檔從零搭建全家桶框架教程步驟上都差不多第一步,依賴總覽完成到我現(xiàn)在半成品的過(guò)程中,目前完成開發(fā)模式的相關(guān)操作,添加了按需加載的地步。 寫在前面 準(zhǔn)備學(xué)習(xí)一下react和webpack相關(guān)的東西,官方的腳手架看起來(lái)太繁瑣,所以打算自己來(lái)搭建一個(gè),參考了這個(gè)文檔從零搭建React全家桶框架教程;...

    cod7ce 評(píng)論0 收藏0
  • 關(guān)于Vue2一些值得推薦文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請(qǐng)點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語(yǔ)。葉上初陽(yáng)乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長(zhǎng)安旅。五月漁郎相憶否。小楫輕舟,夢(mèng)入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請(qǐng)::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...

    sutaking 評(píng)論0 收藏0
  • 關(guān)于Vue2一些值得推薦文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請(qǐng)點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語(yǔ)。葉上初陽(yáng)乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長(zhǎng)安旅。五月漁郎相憶否。小楫輕舟,夢(mèng)入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請(qǐng)::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...

    khs1994 評(píng)論0 收藏0
  • 為什么我不推薦你使用vue-cli創(chuàng)建腳手架?

    摘要:后來(lái)經(jīng)過(guò)排查你會(huì)發(fā)現(xiàn)是由于目前還沒有版本??梢允褂迷摲绞浇鉀Q。這就是我為什么不推薦你使用創(chuàng)建腳手架的原因此文的受眾是想要進(jìn)階中級(jí)的初級(jí)前端人員。 最近在知乎看到一個(gè)問題,原問題如下: 很奇怪,為什么現(xiàn)在能找到自己手動(dòng)創(chuàng)建vue腳手架的文章非常少,而且大家似乎對(duì)webpack4的熱情并不高,對(duì)于想基于vue2.0+webpack4搭建一個(gè)腳手架的我來(lái)說(shuō)資料真是少得可憐。難道現(xiàn)在一般的做...

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

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

0條評(píng)論

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