Webpack【Webpack图片处理、Webpack中proxy代理 、自动清理dist、Webpack优化、JavaScript中的代码检查】(三)-全面详解(学习总结---从入门到深化)(上)

简介: Webpack【Webpack图片处理、Webpack中proxy代理 、自动清理dist、Webpack优化、JavaScript中的代码检查】(三)-全面详解(学习总结---从入门到深化)

Webpack图片处理



在Webpack中,一切皆模块,图片也不例外,也需要我们单独处理一下


安装


图片处理是通过 url-loader

npm install --save-dev url-loader@4.1.1


增加配置

{
  test: /\.(png|svg|jpe?g|gif)$/i,
    use: {
      loader:"url-loader",
        options:{
          // 阈值,小于20 * 1024kb,进行base64转码
         limit:20 * 1024,
          // img/存放路径 [name]:图片名字 [hash:8]:hash8位 [ext]:后缀
       name:"img/[name].[hash:8].[ext]"
       }
   }
}


此时,可以添加效果20 * 1024 kb的图片,并进行测试


温馨提示

如果图片大于20 * 1024kb,则需要安装 file-loader

npm install --save-dev file-loader@6.2.0 


不在需要做任何额外操作,即可引入大于20 * 1024kb,则是直接拷贝到 dist/img/ 目录下


特别提示

这里字体图标也是可以识别的,这也是Webpack5版本带来的优势,一次性全处理了~~~


Webpack中proxy代理



在做网络请求的时候,前端最常见的问题就是跨域,分别可以在前端和后端处理


前端


1、JSONP(需要服务器端支持)

2、proxy代理(开发模式)


后端


1、cors


安装网络请求方案

npm install --save-dev axios@0.27.2


增加配置


webpack.dev.config.js 增加配置

devServer:{
  proxy: {
    //定义一个标记,如以后api开头的请求都走代理的设置
    '/api': {
      // 要请求的真实服务端基地址 相当于被/api替代了
      target: 'http://iwenwiki.com',
      //把api重写为空,因为别人没有 /api
      pathRewrite: {
        "^/api": ""
     },
      //发送请求头中host会设置成target
      changeOrigin: true
   }
 }
}


实现网络请求

import axios from "axios"
axios.get("/api/api/FingerUnion/list.php").then(res=>{
  console.log(res.data)
})


自动清理dist



为了每次打包发布时自动清理dist目录下的文件(避免旧的文件会保留)


可以安装 clean-webpack-plugin 插件


安装

npm install --save-dev clean-webpack-plugin@3.0.0


插件的配置

// webpack.prod.config.js
const commonConfig = require("./webpack.config");
const { merge } = require("webpack-merge");
const { CleanWebpackPlugin } = require('clean-webpack-plugin')
const cleanPlugin = new CleanWebpackPlugin()
const prodConfig = {
  mode: 'production',
  devtool: 'nosources-source-map',
  plugins: [cleanPlugin]
}
module.exports = merge(commonConfig,prodConfig)


Webpack优化



Webpack的优化在之前的对Webpack的操作已经有很多,例如:分离开发和生产环境、分离和压缩CSS代码,增加 devtool 优化开发和生产环境的调试等等


接下来再介绍一些优化方案:


1、规定文件处理区域

2、查看文件大小,过大的着手处理


规定文件处理区域


项目中js文件是很多的,尤其是在 node_modules 文件夹中,但是我们需要处理的就有 src 目录下的


所以我们需要指定区域

{
  test: /\.js$/,
  use: ['babel-loader'],
  // 包含只处理 src 目录下的文件
  include: path.resolve(__dirname, 'src'),
}


查看文件大小,过大的着手处理


webpack-bundle-analyzer 是一个打包分析神器,它的界面也清晰,而且能很直观的给出每一个打包出来的文件的大小以及各自的依赖,能够更加方便的帮助我们对项目进行分析


安装: npm install --save-dev webpack-bundle-analyzer


增加配置:

const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer');
module.exports = {
 plugins: [
  new BundleAnalyzerPlugin({
   analyzerPort: 8888, // 指定端口号
   openAnalyzer: false,
 })
]
}


JavaScript中的代码检查



一个前端团队很重要的就是代码规范,有了代码规范才可以保证代码质量


常见的前端代码规范工具:


1、JSLint

2、JSHint

3、ESLint


当然这里我们首推 ESLint ,后续的Webpack中我们也是集成 ESLint


Webpack【Webpack图片处理、Webpack中proxy代理 、自动清理dist、Webpack优化、JavaScript中的代码检查】(三)-全面详解(学习总结---从入门到深化)(下):https://developer.aliyun.com/article/1420357

目录
相关文章
|
7月前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
1896 2
|
2月前
|
JSON JavaScript 前端开发
菜鸟之路Day23一一JavaScript 入门
本文介绍了 JavaScript 的基础内容,包括 JS 的引入方式、基础语法、数据类型、运算符、类型转换、函数、对象(如 Array、String、自定义对象、JSON、BOM 和 DOM)、事件监听,以及 Vue 框架的初步使用。重点讲解了内部和外部脚本的引入、变量声明(var、let、const)、常见输出语句、数组与字符串的操作方法、DOM 操作及事件绑定,并通过实例展示了 Vue 的双向数据绑定和常用指令(v-bind、v-model、v-on、v-if、v-for 等)。
89 7
|
5月前
|
JavaScript 前端开发
【JavaScript】——JS基础入门常见操作(大量举例)
JS引入方式,JS基础语法,JS增删查改,JS函数,JS对象
|
6月前
|
Web App开发 JavaScript 前端开发
如何学习JavaScript?
如何学习JavaScript?
127 5
|
6月前
|
JavaScript 前端开发 索引
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
62 2
|
6月前
|
存储 JavaScript 前端开发
JavaScript学习第一章
本文档介绍了JavaScript的基础知识,包括其在网页中的作用、如何通过JavaScript动态设置HTML元素的CSS属性,以及JavaScript中的变量类型(`var`、`let`、`const`)和数据类型(基本数据类型与引用数据类型)。通过实例代码详细解释了JavaScript的核心概念,适合初学者入门学习。
88 1
|
6月前
|
监控 前端开发 JavaScript
React 静态网站生成工具 Next.js 入门指南
【10月更文挑战第20天】Next.js 是一个基于 React 的服务器端渲染框架,由 Vercel 开发。本文从基础概念出发,逐步探讨 Next.js 的常见问题、易错点及解决方法,并通过具体代码示例进行说明,帮助开发者快速构建高性能的 Web 应用。
283 11
|
6月前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
946 1
|
6月前
|
数据采集 存储 JavaScript
如何使用Puppeteer和Node.js爬取大学招生数据:入门指南
本文介绍了如何使用Puppeteer和Node.js爬取大学招生数据,并通过代理IP提升爬取的稳定性和效率。Puppeteer作为一个强大的Node.js库,能够模拟真实浏览器访问,支持JavaScript渲染,适合复杂的爬取任务。文章详细讲解了安装Puppeteer、配置代理IP、实现爬虫代码的步骤,并提供了代码示例。此外,还给出了注意事项和优化建议,帮助读者高效地抓取和分析招生数据。
276 0
如何使用Puppeteer和Node.js爬取大学招生数据:入门指南
|
7月前
|
存储 JavaScript 前端开发
前端开发:Vue.js入门与实战
【10月更文挑战第9天】前端开发:Vue.js入门与实战