webpack(一)——资源模块,loader,代码分离,缓存

简介: 安装webpack安装webpack需要两个主包,在Vscode上新建一个文件夹,在终端打开,输入node -v检测是否安装了nodejs输入npm -v输入npm install webpack webpack-cli --global安装webpack,会产生一个文件package.json输入命令webpack -v是否安装成功
安装webpack

安装webpack需要两个主包,在Vscode上新建一个文件夹,在终端打开,

  • 输入node -v检测是否安装了nodejs
  • 输入npm -v
  • 输入npm install webpack webpack-cli --global安装webpack,会产生一个文件package.json
  • 输入命令webpack -v是否安装成功

<hr/>

一、资源模块

  1. resource

修改配置文件webpack.config.js

module:{
   rules:[{
     test:/\.png/,
     type:'asset/resource'
   }]
}

输入npx webpaack自定义文件名
在这里插入图片描述
在这里插入图片描述
generator的优先级是大于asset的

  1. inline资源
module:{
   rules:[{
     test:/\.svg/,
     type:'asset/inline'
   }]
}
  1. source
  2. 通用资源 类型

通用资源类型asset,在导出一个data URI和发送一个单独文件之间自动选择。

现在webpack将按照默认条件自动地在resource和inline之间进行选择,小于8kb的文件会视为inline模块,否则视为resource

在这里插入图片描述

二、loader

  1. 加载CSS

    在终端输入npm install css-loader -D安装css-loader

//在webpack.config.js进行配置
{
test:/\.css$/,
use:['style-loader','css-loader']
}
  1. 抽离和压缩CSS

在多数环境下压缩CSS可以在生产环境中节省加载时间,同时可以将css文件抽离成一个单独的文件

需要在终端输入npm install mini-css-extract --save-dev
//在webpack.config.js进行配置
rules:[{
test:/\.css$/i,
use:['MiniCssExtractPlugin.loader','css-loader']
}]

可以自己设定文件名,如下所示

new MiniCssExtractPlugin({
filename:'styles/[contenthash].css'
})
  1. 加载images图像

    可以在加载CSS时处理图像

//在style.css中修改
.block-bg {
background-image:url(./assets/webpack-logo.svg);

//在index.js文件中修改
block.style.cssText:'width:200px,height:200px;background-color:#2b3a42'
block.cssList.add('block-bg')
  1. 加载fonts字体

使用Asset Modules可以接收并加载任何文件,然后将其输出到构建目录
在这里插入图片描述

  1. 加载数据
可以加载的有用资源,如JSON文件,csv,tsv,xml,类似于Node.js,JSON支持实际上是内置的,也就是说import
Data from './data.json'默认正常进行。

要导入csv,tsv,xml,可以使用csv-loader和xml-loader,处理加载

在终端输入npm install --save-dev csv-loader xml-loader

//在webpack.config.js中添加配置
module:{
  rules:[{
    test:/\.(csv|tsv)$/i,
    use:['csv-loader'],
  },{
   test:/\.(xml)$/i,
    use:['xml-loader'], },
    ]
}
  1. 自定义 JSON 模块parser

    通过自定义parser替代特定的webpack loader,可以将任何toml,yaml或json5文件作为JSON模块导入
    在这里插入图片描述

在这里插入图片描述

//在webpack.config.js中添加配置
{test:/\.toml$/,
type:'json',
parser:{parse:toml.parse}
},
{test:/\.yaml$/,
type:'json',
parser:{parse:yaml.parse}
},
{test:/\.json5$/,
type:'json',
parser:{parse:json.parse}
},
  1. babel-loader

在终端输入 npm install -D babel-loader @babel/core @babel/preset-env

  • babel-loader 在webpack里应用babel解析ES6的桥梁
  • @babel/core babel核心模块
  • @babel/preset-env babel-loader预设,一组babel插件的组合

三、代码分离

  1. 入口起点

    这是最简单直观的分类代码的方式

    先在JS文件里导入lodash,因此需要安装

在终端输入 npm install lodash --save-dev
然后修改一下配置文件,如下所示

在这里插入图片描述

  1. 防止重复

配置dependOn option选项,可以在多个chunk之间共享模块:

  1. 动态导入

    当 涉及到动态代码拆分时,webpack提供了两个技术,第一种,也是推荐选择的方式,使用import()语法来实现动态导入,第二种,使用webpack遗留功能使用require.ensure

    4.懒加载(按需加载)

    这种方式实际上最先把你的代码在一些逻辑断点处分离开,然后在一些代码中完成某些操作后,立即引用或即将引用另一些新的代码块
    在这里插入图片描述

四、缓存

  1. 输入文件的文件名
可以通过替换output.filename中的substitutions设置,来定义输出文件的名称
//在webpack.config.js中
output: {
    filename:'[name].[contenthash].js',
        path:path.resolve(_dirname,'./dist'),
            clean:true,
                assetModuleFilename:'images/[contenthash][ext]'
},
    //在集成终端打开 
  1. 缓存第三方库
splitChunks: {
    cashGroups:{
        vendor:{
            test:/[\\/]node_modules[\\/]
            name:'vendors',
                chunks:'all '
        }
    }
}
//打包到vendors.bundle.js
  1. 将 JS 文件放到一个文件夹中

当项目部署到服务器上时浏览器会加载完服务器上的文件会缓存好我们打包好的模块,这样如果我们修改了业务代码,文件名如果没有变,浏览器会使用用户本地缓存内容,

  • 这就需要修改文件的文件名解决,使用可替换模板字符串的方法来定义contenthash, 能实现文章的内容不变,哈希的字符串就不变
  • 第三方代码也需要缓存,通过修改optiminzationChunks属性来实现,可以定义一个casheGroups这个缓存组将们业务代码引用的第三方文件,打包到一个文件中在浏览器中缓存
  • 将所有的JS文件都打包到了一个叫scripts的文件夹中,这就实现了样式,图片,字体JS,等全部资源打包

几个常见的loader

file-loader:把文件输出到一个文件夹中,在代码中通过相对 URL 去引用输出的文件

url-loader:和 file-loader 类似,但是能在文件很小的情况下以 base64 的方式把文件内容注入到代码中去

source-map-loader:加载额外的 Source Map 文件,以方便断点调试

image-loader:加载并且压缩图片文件

babel-loader:把 ES6 转换成 ES5

css-loader:加载 CSS,支持模块化、压缩、文件导入等特性

style-loader:把 CSS 代码注入到 JavaScript 中,通过 DOM 操作去加载 CSS。

eslint-loader:通过 ESLint 检查 JavaScript 代码

目录
相关文章
|
2月前
|
前端开发
在Webpack配置文件中,如何配置loader以处理其他类型的文件,如CSS或图片
在Webpack配置文件中,通过设置`module.rules`来配置loader处理不同类型的文件。例如,使用`css-loader`和`style-loader`处理CSS文件,使用`file-loader`或`url-loader`处理图片等资源文件。配置示例:在`rules`数组中添加对应规则,指定`test`匹配文件类型,`use`指定使用的loader。
|
2月前
|
JavaScript 前端开发
Webpack中loader的使用场景
Webpack中的Loader用于处理和转换模块文件,如将TypeScript转为JavaScript、CSS预处理等,通过配置不同的Loader,可以灵活地支持多种文件类型和语言,实现模块化开发与构建优化。
|
2月前
|
前端开发 JavaScript
webpack 中 loader 和 plugin 的区别
在 webpack 中,loader 用于转换模块的源代码,如将 TypeScript 转为 JavaScript;而 plugin 则扩展了 webpack 的功能,可以执行更复杂的任务,如优化打包文件、注入环境变量等。两者共同作用于构建流程的不同阶段。
|
2月前
|
缓存 监控 前端开发
在资源加载优化中,如何利用浏览器缓存提升性能?
通过以上这些方法,可以有效地利用浏览器缓存来提升资源加载的性能,减少网络请求次数,提高用户体验和应用的响应速度。同时,需要根据具体的应用场景和资源特点进行灵活调整和优化,以达到最佳的效果。此外,随着技术的不断发展和变化,还需要持续关注和学习新的缓存优化方法和策略。
104 53
|
2月前
|
存储 缓存 监控
网站的图片资源是否需要设置缓存?
【10月更文挑战第18天】网站的图片资源一般是需要设置缓存的,但要根据图片的具体特点和网站的需求,合理设置缓存时间和缓存策略,在提高网站性能和用户体验的同时,确保用户能够获取到准确、及时的图片信息。
|
2月前
|
缓存 监控 安全
检测 Webpack 5 持久化缓存是否存在安全漏洞
【10月更文挑战第23天】通过全面、系统地检测和评估,能够及时发现 Webpack 5 持久化缓存的安全漏洞,并采取有效的措施进行修复,保障项目的安全稳定运行。同时,要持续关注安全技术的发展和变化,不断提升安全检测能力,以应对日益复杂的安全挑战。
|
2月前
|
存储 缓存 监控
配置 Webpack 5 持久化缓存时需要注意哪些安全问题?
【10月更文挑战第23天】通过全面、系统地分析和应对安全问题,能够更好地保障 Webpack 5 持久化缓存的安全,为项目的成功构建和运行提供坚实的安全基础。同时,要保持对安全技术的关注和学习,不断提升安全防范能力,以应对日益复杂的安全挑战。
|
2月前
|
存储 缓存 前端开发
利用 Webpack 5 的持久化缓存来提高构建效率
【10月更文挑战第23天】利用 Webpack 5 的持久化缓存是提高构建效率的有效手段。通过合理的配置和管理,我们可以充分发挥缓存的优势,为项目的构建和开发带来更大的便利和效率提升。你可以根据项目的实际情况,结合以上步骤和方法,进一步优化和完善利用持久化缓存的策略,以达到最佳的构建效果。同时,不断探索和实践新的方法和技术,以适应不断变化的前端开发环境和需求。
|
3月前
|
前端开发 UED
Webpack 中处理 CSS 和图片资源的多 Loader 配置
【10月更文挑战第12天】 处理 CSS 和图片资源是 Webpack 配置中的重要部分。通过合理选择和配置多个 Loader,可以实现对这些资源的精细处理和优化,提升项目的性能和用户体验。在实际应用中,需要不断探索和实践,根据项目的具体情况进行灵活调整和优化,以达到最佳的处理效果。通过对 Webpack 中多 Loader 处理 CSS 和图片资源的深入了解和掌握,你将能够更好地应对各种复杂的资源处理需求,为项目的成功构建和运行提供坚实的基础。
106 1
|
30天前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
172 85