表严肃webpack精讲

安装配置

  • 安装webpack
npm init -y  # npm初始化,生成package.json文件
npm i webpack webpack-cli -D  #安装webpack和webpack-cli

package.json

"scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "pack": "node_modules\\.bin\\webpack --watch" #windows的斜线写法  --watch监听是否有文件修改
  },
  • demo
  1. 整体demo布局


    image.png
  2. 编写文件信息
    js/a.js

var msg = require('./b').msg;
console.log("msg:", msg);

js/b.js

var msg = "Yo.";
module.exports = {msg : msg};

index.html

<body>

<script src="js/pack.js"></script>
</body>

webpack.config.js

module.exports = {
    entry: ".\\js\\a",
    output: {
        filename: 'pack.js',
        path: __dirname + "\\js"
    }
}
  1. 运行
npm run pack # webpakc生成pack.js文件

entry和output

安装同安装webpack

  1. 整体demo布局


    image.png
  2. 编写文件信息
    js/base.js

var open = false;

export{open};

js/home.js

import open from './base'

if(open){
    document.body.innerHTML = 
    `<a href="./signup.html">注册</a>`
}

js/signup.js

import open from './base'

if(open){
    document.body.innerHTML = 
        `<h1>欢迎注册</h1>`
}else{
    document.body.innerHTML = 
        `<h1>没有权限注册</h1>`        
}

page/index.html

<body>

<script src="../dist/home.bundle.js"></script>
</body>

page/signup.html

<body>

<script src="../dist/signup.bundle.js"></script>
</body>

webpack.config.js

module.exports = {
    entry:{
        home: "./js/home.js",
        signup: "./js/signup.js"
    },
    output:{
        filename: "[name].bundle.js",
        path: __dirname + "\\dist"
    }
}
  1. 运行
npm run pack # 自动生成dist目录下的home.bunlde.js和signup.bundle.js

leader

安装同安装webpack

  1. 整体demo布局


    image.png
  2. 编写文件信息
    js/base.js

var debug = true;

export{debug}

js/index.js

import debug from "./base";
import "../css/base.css";
import "../css/base2.css"

console.log('debug:' ,debug);

index.html

<body>

<script src="./dist/bundle.js"></script>
</body>

css/base.css

body{
    background: #ccc;
}

css/base2.css

body{
    background: #000;
}

webpack.config.js

module.exports = {
    entry: "./js/index.js",
    output:{
        filename: "bundle.js",
        path: __dirname + "\\dist",
    },
    module: {
        rules:[
            {
                test: /\.css$/,
                //***use从右往左开始***
                use:['style-loader' ,'css-loader']
            }
            
        ]
    }

}
  1. 安装css-loader和style-loader
npm i css-loader style-loader -D
  1. 运行
npm run pack # 自动生成dist目录下的bundle.js

动态加载样式

安装同安装webpack

  1. 整体demo布局


    image.png

2.编写文件内容
index.js

import "./index.css";
import "./index2.css";
console.log("Yo.!!!");

index.html

<script src="./dist/bundle.js"></script>

index.css




body {
    background: royalblue;
}

index2.css

body {
    border: 2em solid;
}

webpack.config.js

module.exports = {
    mode: "development",
    entry: "./index.js",
    output:{
        filename: "bundle.js",
        path: __dirname + "\\dist",
    },
    module:{
        rules: [
            {
                test: /\.css$/i,
                //***从下往上开始的***/
                use: [
                    {
                        loader: "style-loader/url", // 将<link>插入到<head>中
                    },
                    {
                        loader: "file-loader", // 加载文件且生成文件地址
                        options: {
                            publicPath: './dist', // 公共目录,即地址栏中的目录地址
                            name: '[name].bundle.css', // 文件名
                        },
                    },
                ],
            },
        ],
    },
}
  1. 安装file-loader、css-loader和style-loader
npm i file-loader css-loader style-loader -D 
  1. 运行
npx webpack -w    //自动生成dist目录下的bundle.js、index.bundle.css和index2.bundle.css

动态加载文件

  • 加载文件地址
    安装同安装webpack
  1. 整体demo布局


    image.png
  2. 编写文件内容
    index.js
import './index.css';
import src from "./img/chong.jpg";

let  img = document.createElement('img');
img.src = src;
document.body.appendChild(img);

index.html

<body>
    
<script src="./dist/bundle.js"></script>
</body>

index.css

body {
    background: url("./img/xiu.gif");
}

img {
    max-width: 20em;
}

webpack.config.js

module.exports = {
  mode   : 'development',
  entry  : './index.js',
  output : {
    filename   : 'bundle.js',
    path       : __dirname + '/dist',
    publicPath : './dist/', // 公开文件相对index.html的地址
  },
  module : {
    rules : [
      // CSS loader
      {
        // 以.css结尾的文件
        test : /\.css$/i,
        use  : [ 'style-loader', 'css-loader' ],
      },
      // 图片 loader
      {
        // 以.jpg、.jpeg、.png或.gif结尾的文件
        test : /\.(jpg|jpeg|png|gif)$/i,
        use  : [
          {
            loader : 'file-loader',
          },
        ],
      },
    ],
  },
};
  1. 安装file-loader、css-loader和style-loader
npm i file-loader css-loader style-loader -D 
  1. 运行
npx webpack -w    //自动生成dist目录下的bundle.js、xxx.gif和xxx.jpg
  • 直接转换图片数据
  1. 整体demo布局


    image.png
  2. 编写文件内容
    index.js

import  c from "./img/chong.jpg";
import  g from "./img/gua.jpg";
import  l from "./img/lian.jpg";
import  x from "./img/xiu.gif";

let container = document.querySelector('.container');
let body      = document.body;

function append (src, parent) {
  let img = document.createElement('img');
  img.src = src;
  parent.appendChild(img);
}

append(c, container);
append(g, container);
append(l, container);
append(x, body);

index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <style>
      .container {
        font-size: 0;
      }
    
      img {
        width: 33.3333333%
      }
    </style>
</head>
<body>
  
<div class="container"></div>

<script src="dist/bundle.js"></script>
</body>
</html>

webpack.config.js

module.exports = {
  mode   : 'development',
  entry  : './index.js',
  output : {
    filename   : 'bundle.js',
    path       : __dirname + '/dist',
    publicPath : './dist/',
  },
  module : {
    rules : [
      {
        test : /\.(jpg|png|jpeg|gif)/i,
        use  : [
          {
            loader  : 'url-loader',
            options : {
              limit : 60 * 1024, // byte
            },
          },
        ],
      },
    ],
  },
};
  1. 安装file-loader和url-loader
npm i file-loader url-loader -D
  1. 运行
npx webpack -w  //自动生成dist目录下的bundle.js、xxx.gif

加载数据(json、csv)

安装同安装webpack

  1. 整体demo布局


    image.png
  2. 编写文件内容
  • json
    nav.json
[
    {
      "text": "yo",
      "url": "#yo"
    },
    {
      "text": "ha",
      "url": "#ha"
    },
    {
      "text": "la",
      "url": "#la"
    },
    {
      "text": "muhaha",
      "url": "#muhaha"
    }
  ]

index.js

import list from './nav';
// import list from './nav.csv';

const nav = document.querySelector('nav');

list.forEach(it => {
  if (!it.text)
  return;

  let a       = document.createElement('a');
  a.innerText = it.text;
  a.href      = it.url;

  nav.appendChild(a);
});

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <link rel="stylesheet" href="index.css">
</head>
<body>
<nav></nav>
<script src="./dist/bundle.js"></script>
</body>
</html>

index.css

/* attention */
:root {
    font-family: sans-serif;
}
/* attention */

/* attention */
nav > * {
    display: inline-block;
    padding: .5em;
}
/* attention */
  • csv
    打开index.js第2行注释,注释第一行
    nav.csv
text, url
yo, #yo
ha, #ha
la, #la
muhaha, #muhaha

webpack.config.js

module.exports = {
    mode: "development",
    entry: "./index.js",
    output:{
        filename: "bundle.js",
        path: __dirname + "\\dist",
    },
    module: {
        rules: [
            {
                test:/\.csv$/i,
                use:  [
                    {
                        loader: "csv-loader",
                        options: {
                            header: true,
                        }
                    }
                ]
            }
        ]
    }
}
  1. (若加载csv)安装csv-loader和papaparse
npm i csv-loader papaparse -D
  1. 运行
npx webpack -w

将HTML纳入打包范围

安装同安装webpack

  1. 整体demo布局


    image.png
  2. 编写文件内容

index.js

console.log("1");

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <h1>Yo.</h1>
    <input type="text" disabled>
</body>
</html>

webpack.config.js


const Clean = require('clean-webpack-plugin');
const Html = require('html-webpack-plugin');

module.exports = {
    mode: "development",
    entry: "./index.js",
    output:{
        filename: "bundle.[hash].js",
        path: __dirname + "\\dist",
    },
    plugins: [
        new Clean(), //清除dist目录
        new Html({
            template: './index.html',    //模板文件
            filename: 'index.html',    //修改模板文件打包名称
            minify: {
                collapseBooleanAttributes : true,   //清除boolen值为默认简写
                collapseWhitespace        : true,   //清除空格
                removeComments            : true,   //清除注释
            }
        })
    ]
}
  1. 安装插件clean-webpack-plugin和html-webpack-plugin
npm i clean-webpack-plugin html-webpack-plugin -D

4.运行

npx webpack -w

懒癌的福音

安装同安装webpack

  1. 整体demo布局


    image.png
  2. 编写文件内容

index.html

<h1>Yooooooo.</h1>

webpack.config.js

const Html = require('html-webpack-plugin');

module.exports = {
    mode: "development",
    entry: "./index.js",
    output:{
        filename: "bundle.js",
        path: __dirname + "\\dist",
    },
    plugins: [
        new Html({
            template: './tpl.html',
        })
    ]
}

package.json

  "scripts": {
    "start": "npx webpack-dev-server --open"
  },
  1. 安装html-webpack-plugin和webpack-dev-server
npm i html-webpack-plugin webpack-dev-server -D
  1. 运行
npm run start   //package.json设置了快捷命令

不同模式不同配置

1.整体demo布局


image.png

node_modules文件夹太大,因此删去,直接npm i
package.json

{
  "name": "webpackdemo3",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "start": "npx webpack-dev-server --open --config webpack.dev.js",
    "build": "npx webpack --config webpack.prod.js"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "clean-webpack-plugin": "^2.0.2",
    "html-webpack-plugin": "^3.2.0",
    "webpack": "^4.32.2",
    "webpack-cli": "^3.3.2",
    "webpack-dev-server": "^3.4.1",
    "webpack-merge": "^4.2.1"
  }
}
  1. 编写文件内容

index.html

<h1>Yo.</h1>

webpack.common.js

const Html = require('html-webpack-plugin');

module.exports = {
  entry  : './index.js',
  output : {
    filename : 'bundle.js',
    path     : __dirname + '/dist',
  },
};

webpack.dev.js

const Html  = require('html-webpack-plugin');
const merge = require('webpack-merge');

module.exports = merge(require('./webpack.common'), {
  mode    : 'development',
  devtool : 'inline-source-map',
  plugins : [
    new Html({
      template : './tpl.html',
    }),
  ],
});

webpack.prod.js

const Clean = require('clean-webpack-plugin');
const Html  = require('html-webpack-plugin');
const merge = require('webpack-merge');

module.exports = merge(require('./webpack.common'),
  {
    mode    : 'production',
    plugins : [
      new Clean(),
      new Html({
        template : './tpl.html',
        minify   : {
          collapseWhitespace : true,
          removeComments     : true,
        },
      }),
    ],
  });
  1. 运行

开发模式

npm start    //package.json设置了快捷命令

生产模式

npm run build //package.json设置了快捷命令
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,194评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,058评论 2 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,780评论 0 346
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,388评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,430评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,764评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,907评论 3 406
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,679评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,122评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,459评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,605评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,270评论 4 329
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,867评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,734评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,961评论 1 265
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,297评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,472评论 2 348

推荐阅读更多精彩内容

  • 版权声明:本文为博主原创文章,未经博主允许不得转载。 webpack介绍和使用 一、webpack介绍 1、由来 ...
    it筱竹阅读 11,051评论 0 21
  • 目录第1章 webpack简介 11.1 webpack是什么? 11.2 官网地址 21.3 为什么使用 web...
    lemonzoey阅读 1,731评论 0 1
  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,679评论 7 110
  • webpack使用学习 本分享学习借鉴webpack中文官网,官网链接(中文文档):https://www.web...
    腿毛怪丶叔叔阅读 870评论 0 5
  • webpack 介绍 webpack 是什么 为什么引入新的打包工具 webpack 核心思想 webpack 安...
    yxsGert阅读 6,458评论 2 71