webpack 基础配置

news2025/5/25 1:43:52

常见配置

  1. 文件打包的出口和入口
  2. webpack如何开启一台服务
  3. webpack 如何打包图片,静态资源等。
  4. webpack 配置 loader
  5. 配置 plugin
  6. 配置sourceMap
  7. 配置 babel 语法降级等

接下来 , 我们先从webpack的基本配置 开始吧!

在准备 配置之前 , 搭建一个 webpack 工程 , 你可以在自己的工程下

npm init 或者 yarn init

1: 你可以设置 项目名称 , 描述,入口文件 , 发布的url 等等 ,你也可以一路 Enter 下去。

在这里插入图片描述
运行上方代码

接着 我们就得到了一个 package.json 文件 , 该文件就是用来保存,运行脚本 , 依赖包 , 版本信息等等配置文件。
然后,我们需要在根目录下创建一个 webpack.config.js文件 ,该文件就是编写webpack的一些配置的文件。

2: 依赖包 下载
上面我们已经将文件创建出来了 , 接下来 ,我们既然需要 依赖webpack 对项目进行打包,那我们 就需要下载对应的资源包。

//下载webpack cli ,这里的-D 是指开发时依赖的资源包,到生产上就不会再下载了
npm install -D webpack-cli

在这里插入图片描述

下载,完成后 执行 npx webpackwebpack 会将 src/index.js进行打包输出到 dist 目录下

3: 运行脚本执行

package.json 文件中 配置脚本

   "test": "echo \"Error: no test specified\" && exit 1",
   "build": "webpack",
   "watch": "webpack --watch",
   "dev": "webpack-dev-server"

接下来 你只需要执行 npm run build 就可以对项目进行构建了。
4 :webpack配置打包的入出口文件

module.exports = {
  entry : './src/index.js'  // 配置打包入口文件
  output : { // 配置打包完成的出口文件 路径 
    path : path.resolve(__dirname , './dist/'),
    filename : 'building.js'
  }
}

5: webpack开启本地服务

  • 下载 webpack-dev-server 依赖
    webpack-dev-server 原理:
    • 在本地开启一台 express 服务器。

    • package.json 文件中 ,加上上面这段配置,接下来你可以 npm run dev,浏览器中输入 http://localhost:8080/

        "dev": "webpack-dev-server"
      

      同时 你也可以在 webpack.config.js文件中配置 devServer

      const path = require("path");
      
      module.exports = {
       devServer : {  // 
         host : 'localhost', // 服务启动的 ip 地址 localhost 即本地
         port : '3000', // 开启的端口
         open : true // 是否开启服务后 打开浏览器
       },
       entry : './src/index.js',
       output : {
         path : path.resolve(__dirname , './dist/'),
         filename : 'building.js'
       }
      }
      

      于是你发现了一个神奇的问题,页面白屏了 ,报错找不到资源。

      • 页面白屏
        先说原因,由于 我们访问 http://localhost:8080 打包完成后 默认访问的是 dist 目录下的index.html 但我们发现打包完成后 , dist 目录下并没有index.html 所以就没找到资源。
        在这里插入图片描述
        解决方法
        通过 html-webpack-plugin插件 可以在打包完成后会自动在 dist 目录下 创建一个 index.html ,但需要你编写它的配置。

        const HtmlWebpackPlugin = require('html-webpack-plugin')
        module.exports = {
          plugins : [
            new HtmlWebpackPlugin({
              filename : 'index.html',  // 生成的文件名
              template : '/index.html' // 将哪个模板作为html
            })
          ],
        }
        

      配置完成后,需要先打包,再重新启动服务即可正常显示

      webpackcss , less sass 静态资源的处理。

      我们知道 webpack 打包 css 的时候 是将所有的 css 注入到 html 文件的 style 标签中,然后才会样式生效。

      • 打包 css

      那如何让 webpack帮助我们将 css 进行打包呢 ?

      下载 css-loader 和 style-loader

      yarn add css-loader -D 
      yarn add style-loader -D 
      或者 
      npm install  css-loader -D 
      npm install style-loader -D 
      

      配置 webpack.config.js

      // 在配置中 添加该选项 
      module : {
      rules : [
          {
          test : /\.css$/,
          use : ['style-loader','css-loader']
          }
              ] 
      }
      

      注意 ,webpack 解析 loader的顺序是 从右到左进行解析

      插入一条 常见面试题

      面试官 : style-loader 和 css-loader 的区别?

      css-loader ,主要是 解析我们编写的 css ,因为 css 本身并不是一个模块,所以在js 中导入 css 你就需要 css-loader 来识别它们,而 style-loader 就是将 css-loader 解析完的结果 ,作为样式内容插入到 html style标签内,这样我们样式就生效了。

      • 处理 less sass
        我们 开发中 常用的 less sass 这些 预处理器 编写的 css 怎么处理呢 ? 接下来要讲的是 webpack处理 less sass 编写的样式

        import './styles/index.less'; // 导入我们的 less文件 
        console.log('111');
        
        less复制代码.name {
          color:  red;
        }
        ul> li {
          font-size: 25px;
        }
        

        当你编写完成后 , 保存,终端会 提示,你可能需要一个 loader 来处理这种文件类型。

        ERROR in ./src/styles/index.less 1:0
        Module parse failed: Unexpected token (1:0)
        You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders
        > .name {
        |   color:  red;
        | }
         @ ./src/index.js 1:0-29 
        

        我们在此时 需要下载一个 less-loader

        yarn add less-loader sass-loader -D 或者
        npm install less-loader sass-loade -D 
        
         module : {
            rules : [
              {
                test : /\.css/,
                use : ['style-loader' , 'css-loader']
              },
              {
                test : /\.less/,
                use : ['style-loader' , 'css-loader' , 'less-loader']
              },
              {
                test : /\.sass/,
                use : ['style-loader' , 'css-loader' , 'sass-loader']
              }
            ]
          },
        

        3:webpack 处理静态资源

        问题 : 图片资源以相对路径引入打包后,webpack无法展示。
        原因 :

        • 我们服务开启后,index.html中 通过 ./ 寻找,

        • 但打包完成的 dist 目录下根本没有这张1.png 这张图片,这是由于webpack打包并没有将我们的静态资源打包进去

          接下来就看一下如何将 静态资源添加到webpack打包选项中去吧。

          <!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>Document</title>
          </head>
          <body>
            <div class="name">张三</div>
            <img src="./src/img/1.png" alt="">
            <ul>
              <li>
                dasdasdasdas
              </li>
            </ul>
            <script src="./main.js"></script>
          </body>
          </html>
          

          下载 file-loader 或者 url-loader —> npm install file-loader -D 或者 yarn add file-loader -D

          配置

          module : {
              rules : [
                {
                  test : /\.css$/,
                  use : ['style-loader' , 'css-loader']
                },
                {
                  test : /\.less$/,
                  use : ['style-loader' , 'css-loader' , 'less-loader']
                },
                {
                test : /\.(png|jpeg|jpg|bmp)$/,
                 use : {
                  loader : 'file-loader', // 使用的什么loader 当然你也可以使用 url-loader ,url-loader是封装了file-loaer。
                  options: {
                   outputPath : 'images', // 输出到 dist 哪个 目录下,
                   limit : 5 * 1024,
                   name : '[name].[ext]' // 生成的文件名称 [name] : 原文件名称 [ext] : 原文件后缀 , [hash] :生成哈希值字符串
                  }
                 }
                }
              ]
            },
          

        webpack 之 babel编译js高级语法代码

        我们在编写 js时 一般会 使用 ES6一些高级语法特性,但此时 有些旧的版本浏览器本身是不支持这些高级语法的,例如 es6 里的 class ,其实就是 原型继承的语法糖,如果class不做降级处理,会照成程序暂停运行情况。
        那我们 接下来先了解一下 ,与 bebel 相关的一些降级核心包。

        1. @babel/babel-core // babel的核心包

        2. @babel/preset-env // babel 的语法转换包

        3. babel-loader // babel-loader 对语法进行编译转换的loader
          在转换之前 , 你需要先下载该包,下载完成之后,我们接下来进行配置,在 rules 规则中 新增一条 匹配规则

          { 
                  test : /\.js$/,
                  use : {
                    loader : 'babel-loader',
          
                  },
                  exclude : /node_modules/
                  
           },
          

          或者 在根目录下创建 .babelrc 文件在里面编写相关配置

          {
          // babel-plugin-transform-class-properties 对 es6 class 进行转换插件 
          // @babel/plugin-transform-runtime // 帮助你节省代码体积
            "presets" : ["@babel/env"],
            "plugins": ["@babel/plugin-transform-runtime" , "babel-plugin-transform-class-propertiess"]
          }
          

        webpack 配置 sourceMap

        • 什么是 suorceMap
          其实很多人对 sourceMap的理解很 抽象 , 这到底是个 什么东西?
          • 简单来说 sourceMap 生成映射文件 其实就是为了 提高开发效率,更快的映射到代码的每一行,比如说当前我们控制台有打印,sourceMap 就能够更快的帮你定位到 当前打印的那一行。

        配置
        webpack.config.js 中 添加

         devtool : 'cheap-module-source-map'
        

        思考

        • 为什么执行 npx webpack 而不是 npm webpack ?
          解释 : 在平时 开发中 我们 一般会在项目依赖webpack 打包 是在项目中进行下载的 ,开箱即用的效果,并不会在我们电脑上装载webpack构建工具, 当然你也可以 在全局安装 , 而npx 就会在当前项目下寻找webpack 进行构建

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1010601.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PCL 生成空间三角形面点云

系列文章目录 第一章&#xff1a;PCL生成线段点云 第二章&#xff1a;PCL创建圆柱面点云 文章目录 系列文章目录前言一、三角形面是什么&#xff1f;二、三角形面点云创建步骤1.引入库2.创建三角形面点云 总结 前言 点云库 (PCL) 是一个独立的、大规模的、开放的 2D/3D 图像和…

nginx部署vue后显示500 Internal Server Error解决方案

今天部署vue前端项目一直报错500&#xff0c;无法显示出主页面。 一个以为是自己的dist位置没有访问正确或者nginx.conf的位置写的不对&#xff0c;&#xff0c;最后才发现&#xff01;是权限的问题&#xff01;&#xff01; 我要访问/home/ubuntu/myapp/ruoyi/ruoyi-ui/dist的…

python环境安装(windows)

1. python安装 一、官网下载安装包 打开python的 官网链接 https://www.python.org鼠标点击Downloads按钮 点击downloads后&#xff0c;下拉&#xff0c;找到如下界面&#xff0c;里面就是python的各个历史版本 找到想要下载的版本&#xff0c;点击Download后&#xff0c;下拉…

AI绘画Stable Diffusion原理之扩散模型DDPM

前言 传送门&#xff1a; stable diffusion&#xff1a;Git&#xff5c;论文 stable-diffusion-webui&#xff1a;Git Google Colab Notebook部署stable-diffusion-webui&#xff1a;Git kaggle Notebook部署stable-diffusion-webui&#xff1a;Git AI绘画&#xff0c;输入一段…

热缩膜机效果不好怎么办?

热缩膜机也称热收缩机或收缩包装机&#xff0c;主要是采用加热的原理对物品表面的薄膜进行加热收缩&#xff0c;多用于食品、药品、化妆品、纸箱等产品的外包装&#xff0c;使用过收缩机的用户都知道&#xff0c;热收缩机效果不好是常出现的问题&#xff0c;下面就从3个方面和您…

EndNote+有道

EndNote里面有划线翻译的功能&#xff0c;前提是你的电脑里面安装了有道翻译或者百度翻译的客户端。 我更喜欢有道&#xff0c;所以...... 然后点击“快速安装”。完了之后打开如下&#xff1a; 实现翻译的操作如下&#xff1a; ok。

OJ练习第172题——可以攻击国王的皇后

可以攻击国王的皇后 力扣链接&#xff1a;1222. 可以攻击国王的皇后 题目描述 在一个 8x8 的棋盘上&#xff0c;放置着若干「黑皇后」和一个「白国王」。 给定一个由整数坐标组成的数组 queens &#xff0c;表示黑皇后的位置&#xff1b;以及一对坐标 king &#xff0c;表…

Element UI 表单验证规则动态失效问题

Element 版本&#xff1a;v2.15.3 问题背景 如下代码所示&#xff1a;有一个上传文件的 input 组件&#xff0c;在更新的时候&#xff0c;如果不上传文件表示不更新&#xff0c;如果要更新则点击 「重新上传」按钮将上传组件显示出来 <el-form ref"form" :mode…

计算机网络:三次握手与四次挥手

摘取作者&#xff1a;拓跋阿秀 三次握手 三次握手&#xff08;Three-way Handshake&#xff09;其实就是指建立一个TCP连接时&#xff0c;需要客户端和服务器总共发送3个包。进行三次握手的主要作用就是为了确认双方的接收能力和发送能力是否正常、指定自己的初始化序列号为后…

用于人类复杂疾病成药性评估的R包:DREAM包

已获批药物开发新适应症时&#xff0c;需要对所研究的疾病进行彻底的成药性评估。先前成药性主要通过三种不同的方法进行评估&#xff0c;第一种方法基于公共存数据&#xff0c;关注不同治疗条件下药物的作用机制&#xff08;MOA&#xff09;&#xff1b;第二种是基于网络&…

WEB漏洞原理之---【XMLXXE利用检测绕过】

文章目录 1、概述1.1、XML概念1.2、XML与HTML的主要差异1.3、XML代码示例 2、靶场演示2.1、Pikachu靶场--XML数据传输测试玩法-1-读取文件玩法-2-内网探针或攻击内网应用&#xff08;触发漏洞地址&#xff09;玩法-3-RCE引入外部实体DTD无回显-读取文件开启phpstudy--apache日志…

一文弄懂基于图搜索的路径规划算法JPS(有python代码)

基于图搜索路径规划-JPS 关注晓理紫并回复jps获取代码 [晓理紫] 1、 Jump Point Search&#xff08;跳点搜索&#xff09; 核心&#xff1a;寻找到规划中的对称性 Path 并打破他们&#xff0c;从而避免扩展大量无用节点。 A*搜索的节点JPS 搜索的节点 1.1 概念 强迫邻居 节点…

【深度学习】 Python 和 NumPy 系列教程(十八):Matplotlib详解:2、3d绘图类型(4)3D曲面图(3D Surface Plot)

目录 一、前言 二、实验环境 三、Matplotlib详解 1、2d绘图类型 2、3d绘图类型 0. 设置中文字体 1. 3D线框图&#xff08;3D Line Plot&#xff09; 2. 3D散点图&#xff08;3D Scatter Plot&#xff09; 3. 3D条形图&#xff08;3D Bar Plot&#xff09; 4. 3D曲面图…

Copymonkey:AI生成营销广告文案

【产品介绍】 CopyMonkey.ai 是一家成立于2021年的创新型人工智能&#xff08;AI&#xff09;初创企业&#xff0c;专注于开发一款强大的AI写作助手。我们的产品旨在帮助用户以更高效且更自然的方式创作各种文本内容&#xff0c;无论是文章、博客、电子邮件、简历还是其他类型的…

ARM核心时间线

指令集架构处理器家族(ARM RISC)ARMv1ARM1ARMv2ARM2、ARM3ARMv3ARM6、ARM7ARMv4StrongARM、ARM7TDMI、ARM9TDMIARMv5ARM7EJ、ARM9E、ARM10E、XScaleARMv6ARM11、ARM Cortex-MARMv7ARM Cortex-A、ARM Cortex-M、ARM Cortex-RARMv8-A armv8.2Cortex-A35、Cortex-A50系列[18]、Cor…

华为云云耀云服务器L实例评测|在Docker环境下部署ZPan个人网盘系统

华为云云耀云服务器L实例评测&#xff5c;在Docker环境下部署ZPan个人网盘系统 一、云耀云服务器L实例介绍1.1 云耀云服务器L实例简介1.2 云耀云服务器L实例特点 二、ZPan介绍2.1 ZPan简介2.2 ZPan特点 三、华为对象存储服务OBS介绍3.1 华为OBS介绍3.2 华为OBS应用场景 四、本次…

部分依赖图(Partial Dependence Plots)以及实战-疾病引起原因解释

接上篇&#xff0c;特征重要性解释 特征重要性展示了每个特征发挥的作用情况&#xff0c;partial dependence plots可以展示一个特征怎样影响的了预测结果。 前提同样是应用在模型建立完成后进行使用&#xff0c;概述如下&#xff1a; 首先选中一个样本数据&#xff0c;此时想…

企业级镜像仓库Harbor的安装与配置

企业级镜像仓库Harbor的安装与配置 HarborHarbor概述安装Harbor配置 Harbor运行安装程序脚本登录启动与停止Harbor 登录Harbor仓库登录异常解决方案登录退出 推送拉取Harbor镜像镜像命名规范创建项目推送镜像拉取镜像 Harbor Harbor概述 Harbor是一个开源的容器镜像仓库管理系…

零售超市如何应对消费者需求?非常全面!

随着科技的飞速发展和消费者期望的不断演变&#xff0c;零售行业正经历着一场深刻的革命。传统零售模式逐渐被新零售模式所取代&#xff0c;而其中一个备受关注的元素是自动售货机。 自动售货机不仅在商场、车站和办公楼等高流量地点迅速扩张&#xff0c;还在重新定义我们如何购…

日志平台搭建第七章:Linux安装kafka-manager

相关链接https://github.com/yahoo/kafka-manager/releases kafka-manager-2.0.0.2下载地址 百度云链接&#xff1a;https://pan.baidu.com/s/1XinGcwpXU9YBF46qkrKS_A 提取码&#xff1a;tzvg 一、安装部署 1.把kafka-manager-2.0.0.2.zip拷贝到目录 /opt/app/elk 2.解压…