首页 > 其他分享 >Webpack 4(一)

Webpack 4(一)

时间:2022-08-26 14:16:26浏览次数:84  
标签:webpack js Webpack path loader css

模块打包工具的由来

Web1.0

  • 编写静态页面
  • 表单验证和动效

Web2.0 之 AJAX

  • 管理数据
  • 和用户进行数据交互

大前端开发

  • PC 端
  • 移动端
  • 小程序
  • APP

现代 Web 开发“问题”

  • 采用模块化开发
  • 使用新特性提高效率保证安全性
  • 实时监听开发过程使用热更新
  • 项目结果打包压缩优化

使用 Webpack 实现项目工程化

模块打包工具概要

  • 模块打包器(Module bundler)
  • 模块加载器(Loader)
  • 代码拆分(Code Splitting)
  • 资源模块(Asset Module)

打包工具解决的是前端整体的模块化,并不单指 JavaScript 模块化

Webpack 快速上手

安装 Webpack

yarn init -y
yarn add webpack@4.40.2 webpack-cli@3.3.9 --dev
yarn webpack --version

编写代码

// src/heading.js
export default () => {
  const element = document.createElement('h2')

  element.textContent = 'Hello World'
  element.addEventListener('click', () => {
    alert('Hello Webpack')
  })

  return element
}
// src/index.js
import createdHeading from './heading.js'

const heading = createdHeading()

document.body.append(heading)
<!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>Webpack - 快速上手</title>
</head>
<body>
  <script type="module" src="src/index.js"></script>
</body>
</html>

执行 Webpack 命令

yarn webpack

image

webpack 配置文件

// webpack.config.js
// 该文件是运行在 Node.js 中,所以需要按照 Common.js 的方式编写代码
const path = require('path')

module.exports = {
  // 指定打包入口文件的路径,如是相对路径,./ 不可省略
  entry: './src/main.js',
  // 输出文件配置
  output: {
    filename: 'bundle.js',
    // 只能使用绝对路径
    path: path.join(__dirname, 'output')
  }
}

配置打包命令

{
  "name": "01-getting-started",
  "version": "1.0.0",
  "main": "index.js",
  "license": "MIT",
  "scripts": {
    "build": "webpack"
  },
  "devDependencies": {
    "webpack": "^4.40.2",
    "webpack-cli": "^3.3.9"
  }
}

执行命令

yarn build

image

Webpack 工作模式

如未设置 mode 属性,webpack 会默认使用 production 模式去做工作,除此之外还有 developmentnone 模式,这三种的模式的差异,详见官方文档

image

production 模式

会自动启动一些优化插件,如自动压缩代码等

image

development 模式

webpack 会自动优化打包的速度,并会自动添加一些调试过程中需要的辅助到代码中。

yarn webpack --mode development

image

none 模式

运行最原始的模式打包,不会做任何额外的处理。

yarn webpack --mode none

通过配置文件 mode 属性设置 webpack 工作模式

// 该文件是运行在 Node.js 中,所以需要按照 Common.js 的方式编写代码
const path = require('path')

module.exports = {
  // 设置工作模式
  mode: 'development',
  // 指定打包入口文件的路径,如是相对路径,./ 不可省略
  entry: './src/main.js',
  // 输出文件配置
  output: {
    filename: 'bundle.js',
    // 只能使用绝对路径
    path: path.join(__dirname, 'dist')
  }
}

Webpack 资源模块加载

webpack 默认只会处理 JS 文件,此时直接加载 CSS 则会报错,需要使用配置相对应的处理加载器 loader。loader 是 webpack 的核心特性,借助于 loader 就可以加载任何类型的资源。

image

image

image

加载 CSS

编写 css 代码

// src/main.css
body {
  margin: 0 auto;
  padding: 0 20px;
  max-width: 800px;
  background-color: yellow;
}

安装 css-loader

yarn add css-loader --dev

TypeError: this.getOptions is not a function

image

原因 css-loader@6.7.1 版本过高,降回 css-loader@3.2.0

image

image

安装 style-loader

该 loader 的作用是将经过 css-loader 转换后的结果,通过 style 标签的形式追加到页面上。

yarn add style-loader@1.0.0 --dev
// 该文件是运行在 Node.js 中,所以需要按照 Common.js 的方式编写代码
const path = require('path')

module.exports = {
  // 设置工作模式
  // mode: 'development',
  mode: 'none',
  // 指定打包入口文件的路径,如是相对路径,./ 不可省略
  // entry: './src/main.js',
  entry: './src/main.css',
  // 输出文件配置
  output: {
    filename: 'bundle.js',
    // 只能使用绝对路径
    path: path.join(__dirname, 'dist')
  },
  module: {
    rules: [
      {
        test: /.css$/,
        // 从后往前执行,先执行最后一个 loader,这里会先执行 css-loader
        use: [
          'style-loader',
          'css-loader'
        ]
      }
    ]
  }
}

运行编译命令

yarn webpack

image

image

Webpack 导入资源模块

webpack 建议在 JS 中引用 css,根据代码的需要动态导入资源。

  • 逻辑合理,JS 确实需要这些资源文件
  • 确保上线资源不缺失,都是必要的

image

// src/heading.css
.heading {
  padding: 20px;
  background: #343434;
  color: #fff;
}
import './heading.css'

export default () => {
  const element = document.createElement('h2')

  element.textContent = 'Hello World'
  element.classList.add('heading')
  element.addEventListener('click', () => {
    alert('Hello Webpack')
  })

  return element
}
// 该文件是运行在 Node.js 中,所以需要按照 Common.js 的方式编写代码
const path = require('path')

module.exports = {
  // 设置工作模式
  // mode: 'development',
  mode: 'none',
  // 指定打包入口文件的路径,如是相对路径,./ 不可省略
  entry: './src/main.js',
  // 输出文件配置
  output: {
    filename: 'bundle.js',
    // 只能使用绝对路径
    path: path.join(__dirname, 'dist')
  },
  module: {
    rules: [
      {
        test: /.css$/,
        // 从后往前执行,先执行最后一个 loader,这里会先执行 css-loader
        use: [
          'style-loader',
          'css-loader'
        ]
      }
    ]
  }
}

Webpack 文件资源加载器

image

安装 file-loader

yarn add file-loader@4.2.0 --dev

引用图片

import createdHeading from './heading.js'
import './main.css'
import icon from './icon.png'

const heading = createdHeading()

document.body.append(heading)

const img = new Image()
img.src = icon

document.body.append(img)

配置 loader

// 该文件是运行在 Node.js 中,所以需要按照 Common.js 的方式编写代码
const path = require('path')

module.exports = {
  // 设置工作模式
  // mode: 'development',
  mode: 'none',
  // 指定打包入口文件的路径,如是相对路径,./ 不可省略
  entry: './src/main.js',
  // 输出文件配置
  output: {
    filename: 'bundle.js',
    // 用来存放打包后文件的输出目录,只能使用绝对路径
    path: path.join(__dirname, 'dist'),
    // 指定资源文件引用的目录,'': 默认值,表示网站根目录,dist /不能省略
    publicPath: 'dist/'
  },
  module: {
    rules: [
      {
        test: /.css$/,
        // 从后往前执行,先执行最后一个 loader,这里会先执行 css-loader
        use: [
          'style-loader',
          'css-loader'
        ]
      },
      {
        test: /.png$/,
        use: 'file-loader'
      }
    ]
  }
}

编译后的代码

image

image

标签:webpack,js,Webpack,path,loader,css
From: https://www.cnblogs.com/dwyWeb/p/16624484.html

相关文章

  • webpack 优化
    SourceMapdevtool配置热模块替换webpackserve默认开启CSSstyleloader实现了js文件需要自己处理//main.js//...if(module.hot){//是否支持热模块替换......
  • webpack中path.join()和path.resolve()区别
    constpath=require('path')path模块提供了用于处理文件和目录的路径的实用工具,使用时引入即可。 1.__dirname和__filename的区别__dirname,是一个成员,用来动态获取......
  • webpack3和webpack4区别
    1.modewebpack增加了一个mode配置,只有两种值development|production。对不同的环境他会启用不同的配置。webpack4中通过内置的mode使用相应模式的内置优化。比如设置mo......
  • purgecss-webpack-plugin 遇到css 模块化后排除的解决方案
    purgecss-webpack-plugin 的作用是在webpack打包的时候排除没用到的css样式,这里如果在css上设置了模块化 module就会导致module的样式在打包的时候被排除,尽管它会有被......
  • webpack5打包图片遇到的问题与解决方案
    使用webpack提供的asset/resource做图片的打包处理,但是只能识别css中的路径,如:.title{color:red;background:url('/src/assets/imgs/456.jpeg');width:10......
  • Webpack 打包 - 5.webpack 打包其它资源
    1.素材准备:首先准备一些矢量图图标,如,阿里矢量图等。(阿里矢量官网:https://www.iconfont.cn/)随便找一些icon下载到本地  解压出来是这样的 2.文件结构 ......
  • Webpack 打包 - 4.webpack 图片资源打包
    1.文件结构   2.安装webpack、webpack-cli$npminit$npmiwebpack@4.41.6webpack-cli@3.3.11-g//(全局)$npmiwebpack@4.41.6webpack-cli@3.3.1......
  • Webpack 打包 - 1.webpack 基本打包(JS、JSON)。
    1.文件结构  2.初始化,生成package.json文件$npminit 2.1安装webpack和webpack-cli.(这里使用的是webpack5以下的版本)$npmiwebpack@4.41.6webp......
  • 按照webpack教程起步自己写的理解 webpack起步 + 管理输出+开发环境设置
    一、webpack起步默认打包一般使用webpack的开头,会有个教程,1.先npminit-y形成package.json,2.然后装webpack和webpack-cli,之后创建一个如下的目录,--save-dev表示开发时......
  • 2022.8.14 模块化、Webpack、Vue-element-admin
    06、模块化相当于形成包6.1、简介模块化产生的背景随着网站逐渐变成”互联网应用程序”,嵌入网页的Javascript代码越来越庞大,越来越复杂。Javascript模块化编程,已经成......