webpack5(一)

这篇具有很好参考价值的文章主要介绍了webpack5(一)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

什么是webpack

webpack是一个静态资源打包工具,它会以一个或者多个文件作为打包的入口,将整个项目的所有文件编译组合成一个或多个文件输出出去。输出的文件就是编译好的文件,可以在浏览器端运行。一般将 webpack 输出的文件称为 bandle 。

webpack 本身的功能也是有限的,一共有两种模式:

开发模式:仅能编译js中 ES Module 语法。
生产模式:可以编译js中 ES Module 语法,还可以压缩 js 代码。
 

为什么需要打包工具

开发时,一般会使用框架、ES6模块化语法、css预处理器等语法进行开发,这样的代码如果想在浏览器运行必须经过编译,成为浏览器能识别的 js、css 等语法后才能运行。
打包工具就是用来编译代码的。同时还可以压缩代码、做兼容性处理、提升代码性能等。

目前一些常用的打包工具:

Grunt、Gulp、Parcel、Webpack、Vite 等等。

npm 和  npx

npm是用来下载包的

npx 是将node_modules文件夹中的 .bin 目录临时添加为环境变量,这样就可以访问该环境变量下的应用程序

npx的作用如下:

1.默认情况下,首先检查路径中是否存在要执行的包(即在项目中);

2.如果存在,它将执行;

3.若不存在,意味着尚未安装该软件包,npx将安装其最新版本,然后执行它;

假设有一个名为my-package的软件包,想要执行它。

好吧,若没有npx,要执行一个软件包,必须通过其本地路径运行来完成,如下所示:

./node_modules/bin/my-package

或在 package.json文件的 scripts section中将其定义为单独的脚本,如下所示:

{
    "name":"something",
    "version": "1.0.0",
    "scripts": {
        "my-package":"./node_modules/bin/my-package"
    }
}

然后使用npm run my-package运行。

现在,运用npx,只需运行npx my-package.,即可轻松实现此目的。

webpack的配置有哪些?核心概念?

webpack有5大核心概念:

1. entry(入口)指示Webpack从哪个文件开始打包。
2. output(输出)指示Webpack打包完的文件输出到哪里,如何命名等。
3. loader(加载器)webpack本身只能处理 js、json等资源,其他资源需要借助 loader 才能解析。
4. plugins(插件)扩展webpack的功能。
5. mode(模式)开发和生产两种模式 development/production。

⚠️注意:output 中的 path 是全部文件的输出路径;但 filename指的只是入口文件输出后的路径。
clean:true,设置打包前清空

webpack.config.js 文件:

const path = require("path") //固定写法 node中的核心模块,专门用来处理路径问题

//依赖于node中的common.js模块化
module.exports = {
    //入口
    entry:'./src/main.js',//相对路径
    //出口 文件的输出路径 一个对象 包含路径和文件名
    output:{
        // __dirname node.js中的变量 用来表示当前文件的文件夹目录
        path:path.resolve(__dirname,'dist'),//绝对路径
        filename:'main.js',
        clean:true,//自动清空上次打包的内容,其实就是在打包前,将整个path目录进行清空,再打包
    },
    //loader 加载器
    module:{
        rules:[
            //loader的配置
        ],
    },
    //plugin 插件
    plugins:[
        //plugin的配置
    ],
    //模式
    mode:'development'//或 production
}

 什么是开发模式

webpack5(一),webpack5,javascript,webpack

如何处理样式资源 

如果需要webpack进行打包,那么必须在入口文件进行引入。

css/less/sass/stylus 都有自己对应的loader,不同的是,如果使用预处理器,预处理器的loader会先将预处理器处理为css文件,然后再继续执行,即将css代码编译成commonjs模块放入js,再将js中的css文件通过创建style标签的方式加入到html中。

1.npm install 需要下载的loader
2.配置方式/内联方式(不推荐)

在webpack.config.js中进行配置:

module.exports = {
  module: {
    rules: [
      { test: /\.css$/, //只检测.css文件
        //执行顺序为从右到左,从下至上
        use: [
              'style-loader',//将js中css文件通过创建style标签添加到html中生效
              'css-loader'//将css代码编译为common.js模块放到js中
             ]
      },
    ],
  },
};

3.将需要打包的资源在入口文件引入。

如何进行图片和字体图标处理

webpack4 中通过 file-loader 和 url-loader 进行图片资源的处理,但是在 webpack5 中,已经将两个 loader 内置到 webpack 中了,只需要简单配置。

项目中的图片优化:
习惯将小于10kb的图片转换为base64(DataUri),减少请求,减轻服务器压力。
对于过大的图片,不适合转为base64,因为转为base64文件体积会变大,越大的图片增加的体积越大,导致整体页面的加载速度变慢。

module.exports = {
  module: {
    rules: [
      { test: /\.(png|jpg|gif)$/, //需要查看的图片后缀
        type:"asset",
        parser:{
            dataUrlCondition:{
                //小于10kb的图片转换为base64
                maxSize:10*1024,//10kb
      },
    ],
  },
};

处理字体图标资源

此时不需要进行 base64 的转换,type 类型也是 asset 下的 resource

module.exports = {
  module: {
    rules: [
      { test: /\.(ttf|woff2?)$/, //需要查看的图片后缀
        type:"asset/resource",
        //也是可以设置generator的值
        generator:{
            filename:"static/media/[hash]/[ext]/[query]",
        }

    ],
  },
};

怎样操作输出文件的打包目录

当我们希望打包出来的文件不是全部堆砌在.dist目录下,希望进行 js/image 的分级目录时:

output中更改 js 输出后的文件路径:

output:{
        path:path.resolve(__dirname,'dist'),//绝对路径
        filename:'static/js/main.js',
    },

module下 rule 中和 asset 同级定义generator

module: {
    rules: [
      { test: /\.(png|jpg|gif)$/, //需要查看的图片后缀
        type:"asset",
        parser:{
            dataUrlCondition:{
                //小于10kb的图片转换为base64
                maxSize:10*1024,//10kb
        },
        generator:{
            //输出的图片名称
            //hash指的是打包完成后,图片会被打包为一串字母数字,此值即为hash值,
            //hash值如果觉得太长可以设置为[hash:10],为只取前十位
            //ext 指的是文件后缀名
            filename:"static/image/[hash]/[ext]/[query]",
        }
    ],
  },

此时,.dist目录下会有一个static文件夹,static文件夹下有两个文件夹,js文件夹下是打包好的入口文件,image文件夹下是打包好的图片资源。文章来源地址https://www.toymoban.com/news/detail-668581.html

到了这里,关于webpack5(一)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • webpack5 学习之路

    1.视频 01-课程介绍_哔哩哔哩_bilibili 2.配套资料 依赖环境 | 尚硅谷 Web 前端之 Webpack5 教程 3.webpack 官方文档 入口起点(entry points) | webpack 中文文档 4.vue cli 官方文档 介绍 | Vue CLI 挖矿:Coding Tree

    2024年02月15日
    浏览(34)
  • Webpack5 SourceMap

    提示:以下是本篇文章正文内容,下面案例可供参考 为什么需要SourceMap 开发时我们运行的代码是经过 Webpack 编译压缩合并之后的,这样的目的是以提高应用程序的性能,但是这种优化也给调试问题带来了困难,因为压缩后的代码难以追踪和调试。这时候,SourceMap技术就能派

    2024年02月13日
    浏览(37)
  • webpack4和webpack5有什么区别

    Webpack4和Webpack5是两个版本的Webpack,其中Webpack5是Webpack的最新版本。 性能:Webpack5相对于Webpack4有更好的性能表现,尤其是在构建速度和Tree Shaking方面。 模块联邦:Webpack5引入了模块联邦的概念,可以让多个Webpack构建的应用程序共享模块,从而减少了代码冗余。 持久性缓存:

    2024年02月01日
    浏览(34)
  • webpack5之模块联邦

    本文将介绍“模块联邦”相关的内容。 联邦模块是 webpack5 提供的一个新特性,它是通过 webpack 原生提供的 ModuleFederationPlugin 插件来实现的。 联邦模块主要是用来解决多个应用之间代码共享的问题,可以让我们的更加方便的实现跨应用的代码共享。 组件复用 复制/粘贴 发布独

    2024年02月15日
    浏览(40)
  • Webpack5入门到原理

    尚硅谷Webpack5新版视频教程 B站直达:https://www.bilibili.com/video/BV14T4y1z7sw 百度网盘:https://pan.baidu.com/s/114lJRGua2uHBdLq_iVLOOQ 提取码:yyds 阿里云盘:https://www.aliyundrive.com/s/UMkmCzdWsGh(教程配套资料请从百度网盘下载) 围观尚硅谷前端课程:http://www.atguigu.com/web 更多尚硅谷视频教程

    2024年02月09日
    浏览(50)
  • Webpack5 基础使用笔记

    [webpack中文文档](概念 | webpack 中文文档 | webpack中文文档 | webpack中文网 (webpackjs.com)): 本质上, webpack 是一个用于现代 JavaScript 应用程序的 静态模块打包工具 。当 webpack 处理应用程序时,它会在内部从一个或多个入口点构建一个 依赖图(dependency graph),然后将你项目中所需的

    2024年02月08日
    浏览(34)
  • Webpack5开发模式选择

    Webpack 5 是一款强大的模块打包工具,可用于将许多分散的模块按照依赖关系打包成一个(或多个)bundle。在Webpack 5中,主要有两种开发模式,分别是开发模式(development)和生产模式(production)。这两种模式主要的区别和各自的作用如下: 开发模式(development):这种模式主

    2024年02月16日
    浏览(44)
  • Webpack5 基本使用 - 2

    loader 是辅助打包工具。 webpack 默认只能打包 js 文件,打包其它模块就需要配置 loader 来告诉 webpack 该怎么去打包其它文件。 loader 可以将文件从不同的语言转换为 JavaScript 。 一类文件如果需要多个 loader 处理, loader 的执行顺序是从后往前。 打包样式文件 打包 css css 文件需要

    2024年01月24日
    浏览(39)
  • Webpack5 对bundle分析

    bundle是Webpack打包的产物,通过分析bundle包的大小和模块关系等信息,我们可以更好地理解代码打包结果,并且继续优化 bundle 大小和性能。 在Webpack 5中, BundleAnalyzerPlugin 是一个用于可视化分析打包结果的插件。它可以生成一个报告,展示打包后各个模块的大小、依赖关系以

    2024年02月15日
    浏览(22)
  • Webpack5 DefinePlugin的作用

    在Webpack 5中,DefinePlugin是一个插件,用于创建全局常量,这些常量可以在编译过程中被引用。它的作用是允许开发人员在代码中定义全局变量,这些变量在构建过程中将被替换为其对应的值。 DefinePlugin并不是必须的,但它是一个非常有用的插件,在某些情况下可以帮助我们优

    2024年02月16日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包