一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - 分享12個Webpack中常用的Loader(小結(jié))

分享12個Webpack中常用的Loader(小結(jié))

2022-02-20 17:37蛙人 js教程

這篇文章主要介紹了分享12個Webpack中常用的Loader(小結(jié)),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

初衷: 整理一些常用的loader分享給大家,方便知道在什么場景下該用什么loader。如果有大佬都懂悄悄左滑就行,不喜勿噴。
適合人群: 前端初級開發(fā)。

style-loader

用途: 用于將css編譯完成的樣式,掛載到頁面style標簽上。需要注意loader執(zhí)行順序,style-loader放到第一位,因為loader都是從下往上執(zhí)行,最后全部編譯完成掛載到style上
安裝

?
1
cnpm i style-loader -D

配置
webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
module.exports = {
 module: {
  rules: [
   {
    test: /\.css/,
    use: ["style-loader"]
   }
  ]
 }
}

css-loader

用途: 用于識別.css文件, 處理css必須配合style-loader共同使用,只安裝css-loader樣式不會生效。
安裝

?
1
cnpm i css-loader style-loader -D

配置
webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
module.exports = {
 module: {
  rules: [
   {
    test: /\.css/,
    use: [
     "style-loader",
     "css-loader"
    ]
   }
  ]
 }
}

sass-loader

用途:css預(yù)處理器,我們在項目開發(fā)中經(jīng)常會使用到的,編寫css非常便捷,一個字 "棒"。
安裝

?
1
cnpm i [email protected] node-sass -D

配置
index.js

?
1
2
3
4
5
6
7
import "index.scss"
 
index.scss
body {
 font-size: 18px;
 background: red;
}

webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
module.exports = {
 module: {
  rules: [
   {
    test: /\.scss$/,
    use: [
     "style-loader",
     "css-loader",
     "sass-loader"
    ],
    include: /src/,
   },
  ]
 }
}

postcss-loader

用途: 用于補充css樣式各種瀏覽器內(nèi)核前綴,太方便了,不用我們手動寫啦。
安裝

?
1
cnpm i postcss-loader autoprefixer -D

配置
postcss.config.js

如果不寫在該文件呢,也可以寫在postcss-loader的options里面,寫在該文件跟寫在那里是同等的

?
1
2
3
4
5
6
7
module.exports = {
 plugins: [
  require("autoprefixer")({
   overrideBrowserslist: ["> 1%", "last 3 versions", "ie 8"]
  })
 ]
}

 

屬性 描述
> 1% 全球超過1%人使用的瀏覽器
> 5% in CN 指定國家使用率覆蓋
last 2 versions 所有瀏覽器兼容到最后兩個版本根據(jù)CanIUse.com追蹤的版本
Firefox ESR 火狐最新版本
Firefox > 20 指定瀏覽器的版本范圍
not ie <=8 方向排除部分版本
Firefox 12.1 指定瀏覽器的兼容到指定版本

 

webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
module.exports = {
 module: {
  rules: [
   {
    test: /\.scss$/,
    use: [
     "style-loader",
     "css-loader",
     "sass-loader",
    "postcss-loader"
    ],
    include: /src/,
   },
  ]
 }
}

babel-loader

用途: 將Es6+ 語法轉(zhuǎn)換為Es5語法。
安裝

?
1
cnpm i babel-loader @babel/core @babel/preset-env -D
  • babel-loader 這是使babel和webpack協(xié)同工作的模塊
  • @bable/core 這是babel編譯器核心模塊
  • @babel/preset-env 這是babel官方推薦的預(yù)置器,可根據(jù)用戶的環(huán)境自動添加所需的插件和補丁來編譯Es6代碼

配置
webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
module.exports = {
 module: {
  rules: [
   {
    test: /\.js$/,
    use: {
     loader: "babel-loader",
     options: {
      presets: [
       ['@babel/preset-env', { targets: "defaults"}]
      ]
     }
    }
   },
  ]
 }
}

ts-loader

用途: 用于配置項目typescript
安裝

?
1
cnpm i ts-loader typescript -D

配置
webpack.config.js
當前配置ts-loader不會生效,只是會編譯識別.ts文件, 主要配置文件在tsconfig.json里

?
1
2
3
4
5
6
7
8
9
10
module.exports = {
 module: {
  rules: [
   {
    test: /\.ts$/,
    use: "ts-loader"
   },
  ]
 }
}

tsconfig.json

?
1
2
3
4
5
6
7
8
{
 "compilerOptions": {
  "declaration": true,
  "declarationMap": true, // 開啟map文件調(diào)試使用
  "sourceMap": true,
  "target": "es5", // 轉(zhuǎn)換為Es5語法
 }
}

webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
module.exports = {
 entry: "./src/index.ts",
 output: {
  path: __dirname + "/dist",
  filename: "index.js",
 },
 module: {
  rules: [
   {
    {
     test: /\.ts$/,
     use: "ts-loader",
    }
   }
  ]
 }
}

html-loader

用途: 我們有時候想引入一個html頁面代碼片段賦值給DOM元素內(nèi)容使用,這時就用到html-loader
安裝

?
1

建議安裝低版本,高版本可能會不兼容導(dǎo)致報錯。我這里安裝的是0.5.5版本
配置
index.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import Content from "../template.html"
 
document.body.innerHTML = Content
 
webpack.config.js
module.exports = {
 module: {
  rules: [
   {
    test: /\.html$/,
    use: "html-loader"
   }
  ]
 }
}

file-loader

用途: 用于處理文件類型資源,如jpg,png等圖片。返回值為publicPath為準。
安裝

?
1
cnpm i file-loader -D

配置
index.js

?
1
2
import img from "./pic.png"
console.log(img) // https://www.baidu.com/pic_600eca23.png

webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
module.exports = {
 module: {
  rules: [
   {
    test: /\.(png|jpg|jpeg)$/,
    use: [
     {
      loader: "file-loader",
      options: {
       name: "[name]_[hash:8].[ext]",
       publicPath: "https://www.baidu.com"
      }
     }
    ]
   }
  ]
 }
}

url-loader

用途: url-loader也是處理圖片類型資源,只不過它與file-loader有一點不同,url-loader可以設(shè)置一個根據(jù)圖片大小進行不同的操作,如果該圖片大小大于指定的大小,則將圖片進行打包資源,否則將圖片轉(zhuǎn)換為base64字符串合并到j(luò)s文件里
安裝

?
1
cnpm i url-loader -D

配置
index.js

?
1
import img from "./pic.png"

webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
module.exports = {
 module: {
  rules: [
   {
    test: /\.(png|jpg|jpeg)$/,
    use: [
     {
      loader: "url-loader",
      options: {
       name: "[name]_[hash:8].[ext]",
       limit: 10240, // 這里單位為(b) 10240 => 10kb
       // 這里如果小于10kb則轉(zhuǎn)換為base64打包進js文件,如果大于10kb則打包到dist目錄
      }
     }
    ]
   }
  ]
 }
}

html-withimg-loader

用途: 我們在編譯圖片時,都是使用file-loader和url-loader,這兩個loader都是查找js文件里的相關(guān)圖片資源,但是html里面的文件不會查找所以我們html里的圖片也想打包進去,這時使用html-withimg-loader
安裝

?
1
cnpm i html-withimg-loader -D

配置
index.html

?
1
2
3
4
5
6
7
8
9
10
11
12
13
<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta http-equiv="X-UA-Compatible" content="IE=edge">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>首頁</title>
</head>
<body>
 <h4>我蛙人</h4>
 <img src="./src/img/pic.jpg" alt="">
</body>
</html>

webpack.config.js
如果打包出現(xiàn)img的src路徑為[Object Module],解決方案有

  • 將file-loader降級到4.2.0
  • 修改options參數(shù)esModule為false
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
module.exports = {
 module: {
  rules: [
   {
    test: /\.(png|jpg|jpeg)$/,
    use: {
     loader: "file-loader",
     options: {
      name: "[name]_[hash:8].[ext]",
      publicPath: "http://www.baidu.com",
      esModule: false
     }
    }
   },
   {
    test: /\.(png|jpeg|jpg)/,
    use: "html-withimg-loader"
   }
  ]
 }
}

vue-loader

用途: 用于編譯.vue文件,如我們自己搭建vue項目就可以使用vue-loader, 以下簡單了解一下,這里就不多贅述啦。
安裝

?
1
cnpm i [email protected] vue vue-template-compiler -D
  • vue-loader 用于識別.vue文件
  • vue 不用多說,識別支持vue語法
  • vue-template-compiler  語法模板渲染引擎 {{}} template、 script、 style

配置
main.js

?
1
2
3
4
5
6
import App from "./index.vue"
import Vue from 'Vue'
new Vue({
 el: "#app",
 render: h => h(App)
})

index.vue

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<template>
 <div class="index">
 {{ msg }}
 </div>
</template>
 
<script>
export default {
 name: 'index',
 data() {
 return {
  msg: "hello 蛙人"
 }
 },
 created() {},
 components: {},
 watch: {},
 methods: {}
}
</script>
<style scoped>
 
</style>

webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
const VueLoaderPlugin = require('vue-loader/lib/plugin')
module.exports = {
 entry: "./src/main.js",
 output: {
  path: __dirname + "/dist",
  filename: "index.js",
 },
 module: {
  rules: [
   {
    test: /\.vue$/,
    use: "vue-loader"
   }
  ]
 },
 plugins: [
  new VueLoaderPlugin()
 ]
}

eslint-loader

用途: 用于檢查代碼是否符合規(guī)范,是否存在語法錯誤。
安裝

?
1
cnpm i eslint-loader eslint -D

配置
index.ts

?
1
2
var abc:any = 123;
console.log(abc)

.eslintrc.js
這里簡單寫幾個規(guī)則

?
1
2
3
4
5
6
7
8
9
10
11
module.exports = {
 root: true,
 env: {
  browser: true,
 },
 rules: {
  "no-alert": 0, // 禁止使用alert
  "indent": [2, 4], // 縮進風格
  "no-unused-vars": "error" // 變量聲明必須使用
 }
}

webpack.config.js

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
module.exports = {
 module: {
  rules: [
   {
    test: /\.ts$/,
    use: ["eslint-loader", "ts-loader"],
    enforce: "pre",
    exclude: /node_modules/
   },
   {
    test: /\.ts$/,
    use: "ts-loader",
    exclude: /node_modules/
   }
  ]
 }
}

總結(jié)

到此這篇關(guān)于分享12個Webpack中常用的Loader(小結(jié))的文章就介紹到這了,更多相關(guān)Webpack常用的Loader內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://juejin.cn/post/6942322281913778206

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲精品91 | 午夜办公室 | 青青草国产精品 | 国产二区视频 | 美女扒开腿让男生桶爽漫画 | 成人私人影院在线观看网址 | 色哟哟在线资源 | jzjzjz日本在线观看 | 欧美视频一区二区三区在线观看 | 国产91精品久久久久久 | chinese特色video| 国内在线播放 | 天天干天天色综合 | 国产福利在线观看第二区 | 蹭蹭妈妈的朋友小说 | 天堂男人在线 | 欧美日韩在线一区二区三区 | 精品蜜臀AV在线天堂 | blacked最大的吊 | 国产一区二区不卡 | 欧美亚洲高清日韩成人 | 免费人成网址在线观看国内 | yellow视频免费观看播放 | 69pao强力打造免费高速 | 我半夜摸妺妺的奶C了她 | 欧美日韩亚洲高清不卡一区二区三区 | 日韩欧美一区二区三区中文精品 | 欧美在线观看一区二区三 | 视频一区在线免费观看 | 99在线观看视频免费 | 国产欧美日韩免费一区二区 | 日本不卡1卡2卡三卡网站二百 | 九九艹| 色老板影视 | 人人爱操 | 羞羞污视频 | 91在线视频导航 | 果冻传媒在线播放观看w | 无套内谢大学生A片 | 法国贵妇一级伦理hd | 四虎成人网 |