首页 > 其他分享 >腿夹腿,带你用react撸后台,系列一(Vite篇)

腿夹腿,带你用react撸后台,系列一(Vite篇)

时间:2024-10-23 14:47:14浏览次数:9  
标签:Vite react vite 后台 config 打包 eslint

Github地址 | 文档地址 | 预览地址

react-antd-console 是一个后台管理系统的前端解决方案,封装了后台管理系统必要功能(如登录、鉴权、菜单、面包屑、标签页等),帮助开发人员专注于业务快速开发。项目基于 React 18Ant design 5ViteTypeScript 等新版本。对于使用到的各项技术,会被持续更新至最新版本。可放心用于生产环境。

为了方便大家更好的掌握和使用本项目,推出系列文章:

  • 腿夹腿,带你用react撸后台,系列一(Vite篇)

如果你喜欢这个项目或认为对你有用,欢迎使用体验和 Star

1. 概述

首先我们需要搞定构建工具问题,我们使用了 Vite 作为构建工具

Vite 是一个超快速的前端构建工具,推动着下一代网络应用的发展

Vite 最大的特点是启动极速(通常1s内)、轻量快速的热更新、对 TypeScript、JSX、CSS 等支持开箱即用。相较于 Webpack 传统构建工具,其配置极简,并同样可以实现我们想要的诸多功能,维护心智负担极低

1.1 Vite的问题

如果一个构建工具存在瓶颈,那么哪怕其他有再好的方面,最终也无法选用。所以我们不能忽视 Vite 的缺点。那就是:

1.1.1 刷新页面慢?

Vite 因为减少了源文件(JS/TS/CSS)的工作量,导致并发请求多而拖慢刷新页面的速度。但结合启动和热更新,在速度上,相比 Webpack,本文档认为仍然具有明显的优势

本项目在开发启动后,刷新首页,共有 168 项请求,耗时 150 至 200 毫秒。作为参考

1.1.2 开发和打包不一致?

理论上是有可能的,因为 Vite 开发使用 esbuild, 打包使用 rollup。但实际情况中,作者从没有碰到过不一致的情况。而且 Vite 即将使用 Rolldown 作为底层打包工具。Rolldown 将保证开发和打包结果完全一致,并提供更快的打包速度。届时可平滑升级

2. Vite 内置

Vite 内置了很多开箱即用的功能,本项目用到的内置功能有:

2.1 样式

样式预处理器我们使用的是 Less。在 Vite 中,只需要安装 less 模块即可直接使用

npm i -D less

本项目没有额外配置 less 选项,若需要进一步配置,可参考 Vite配置 css.preprocessorOptions

2.1.1 打包后,样式名自动加前缀

对于样式名,不同浏览器可能有不同的前缀,例如 -webkit--ms--moz- 等。但我们写代码时并不想写这些前缀,但打包时可以自动生成。Vite 中如果项目包含有效的 PostCSS 配置 (任何受 postcss-load-config 支持的格式,例如 postcss.config.js),它将会自动应用于所有已导入的 CSS。

我们在 <root>/postcss.config.cjs 中配置自动前缀插件:

// postcss.config.cjs
module.exports = {
  plugins: [
    require('autoprefixer'),
  ],
};

参考文档:

2.2 入口

  • html 入口为根目录的 <root>/index.html,可在该 html 中引入入口 ts/tsx 文件
  • 入口 ts/tsx 文件 位于 src/main.tsx,在该文件中,初始化了 react 等

说明:

  • 在开发时,访问本地服务根路径,会返回上述 html 文件
  • 在打包后,根目录的 <root>/dist 文件夹中也会包含打包后的 html 文件,其源码被引入的 ts/tsx 文件和路径,会被自动转换成打包后的文件和路径

打包前:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <link rel="shortcut icon" type="image/x-icon" href="/images/favicon.ico" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>react-antd-console</title>
  </head>
  <body>
    <div id="root"></div>
    <script type="module" src="/src/main.tsx"></script>
  </body>
</html>

打包后:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <link rel="shortcut icon" type="image/x-icon" href="/images/favicon.ico" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>react-antd-console</title>
    <script type="module" crossorigin src="/assets/index-B68Xj7Fq.js"></script>
    <link rel="stylesheet" crossorigin href="/assets/index-CHnsXl1V.css">
  </head>
  <body>
    <div id="root"></div>
  </body>
</html>

2.3 打包

当我们通过 package.json 中的 npm run build:prod 命令打包时,其实是调用了 vite build --mode prod命令。默认情况下,它使用 <root>/index.html 作为其构建入口点,并生成能够静态部署的应用程序包 <root>/dist/。若要部署,我们将打完的包放到 nginx 等服务上即可

我们还可以指定打包后的文件所支持的浏览器目标,例如指定为支持 es2015 浏览器

// vite.config.js
export default defineConfig({
  build: {
    target: 'es2015',
  },
})

参考文档:

2.4 public 目录

public 目录 位于根目录的 <root>/public 文件夹。该目录中的资源在开发时能直接通过 / 根路径访问到,并且打包时会被完整复制到目标目录的根目录下

3. Vite 配置

另外有些功能是需要配置的,Vite 配置极其简洁。配置文件位于根目录的 <root>/vite.config.ts 如下:

// vite.config.ts
export default defineConfig({
  plugins: [
    react(),
    createSvgIconsPlugin({
      iconDirs: [path.resolve(process.cwd(), 'src/assets/svg')],
      symbolId: 'icon-[dir]-[name]',
    }),
  ],
  resolve: {
    alias: {
      '@': path.resolve(__dirname, './src'),
      '@@': path.resolve(__dirname, './examples'),
    },
  },
  server: {
    host: true,
    port: 9527,
    proxy: {
      '/api': {
        target: 'http://localhost:3000',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, ''),
      },
    },
  },
  esbuild: {
    target: 'chrome65',
  },
  build: {
    target: 'es2015',
  },
});

以下功能为配置后生效的功能:

3.1 开发服务

// vite.config.js
export default defineConfig({
  server: {
    host: true,
    port: 9527,
    proxy: {
      '/api': {
        target: 'http://localhost:3000',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, ''),
      },
    },
  },
})
  • server.host 指定服务器应该监听哪个 IP 地址。 如果将此设置为 0.0.0.0 或者 true 将监听所有地址,包括局域网和公网地址
  • server.port 指定开发服务器端口
  • server.proxy 为开发服务器配置自定义代理规则。具体配置继承自 http-proxy
    • 解释: 当请求 /api 开头的 url 时,该请求会被代理到 http://localhost:3000 ,并且请求路径会自动去除 /api

启动服务后,Vite 会使用 esbuild 作为编译工具,我们指定下编译的文件所支持的浏览器版本为 chrome65 以上:

// vite.config.js
export default defineConfig({
  esbuild: {
    target: 'chrome65',
  },
})

3.2 react支持

使用官方的 react 插件 @vitejs/plugin-react,支持:

  • 在开发中启用热更新 (需要 react >= 16.9)
  • 使用自动 JSX 运行时
  • 使用安装体积小的自定义 Babel 插件/预设
// vite.config.js
import react from '@vitejs/plugin-react'

export default defineConfig({
  plugins: [react()],
})

3.3 路径别名

import 文件时,我们常常会把 <root>/src 别名为 @,这样编写代码就比较方便

// vite.config.js
export default defineConfig({
  resolve: {
    alias: {
      '@': path.resolve(__dirname, './src'),
    },
  },
})

3.4 多环境

多环境采用 vite 内置的方案。

  • 当使用 vite --mode localhost 启动项目时,环境的配置文件,对应的是根目录的 <root>/.env.localhost 文件。
  • .env.localhost 文件中定义的环境变量,可通过 const { VITE_API_HOST } = import.meta.env 在代码中引入。
如何新增环境,并新增环境变量?
  1. 在根目录新建 .env.newEnv 文件
  2. .env.newEnv 文件中定义环境变量: VITE_SOME_KEY = someValue
  3. src/vite-env.d.ts 定义 VITE_SOME_KEY 的类型
  4. 在项目的 ts/tsx 文件中引入环境变量 const { VITE_SOME_KEY } = import.meta.env;
3.4.1 指定环境构建

添加构建命令:

// package.json
{
  "scripts": {
    "build:newEnv": "vite build --mode newEnv",
  }
}

执行构建:

npm run build:newEnv

4. 其他 Vite 不相关的工程化配置

4.1 编码规范

项目总体按最小约束原则约束编码规范,只使用了 eslint。你可以根据自己的需求自行添加各规范,如 stylelintprettier

[!TIP]
我们认为在编码规范方面,应当在工程统一性灵活性之间找到一个平衡,而不是一味地使用各种lint类工具作强制约束。你可以找到自己团队的平衡点,定制适合自己团队的编码规范

4.1.1 eslint规则

本项目采用官方建议的通用 eslint 规则,如下:

  • @typescript-eslint/recommendedeslint 官方赞助的社区 typescript 规则)
  • eslint:recommendedeslint 官方推荐规则)
  • eslint-plugin-react (社区流行的 react 规则)

详见 <root>/.eslintrc.cjs

eslint 可配合 huskylint-staged 实现 git commit 时自动校验 eslint,其他文档和教程很多,在此不再赘述

5. 完整版预览

5.1 深/浅色主题

LightDark

5.2 任意主色切换

5.3 任意背景色切换

Background LightBackground Dark

5.4 4种布局

侧分栏侧单栏
头分栏头单栏

5.5 丰富的主题配置

6. 系列文章

  • 腿夹腿,带你用react撸后台,系列一(Vite篇)

如果你喜欢这个项目或认为对你有用,欢迎使用体验和 Star

Github地址 | 文档地址 | 预览地址

标签:Vite,react,vite,后台,config,打包,eslint
From: https://blog.csdn.net/2401_88086015/article/details/143180006

相关文章

  • React实现画布——可绘制矩形和箭头
    目录思路代码效果本文将使用React、JSX、Rough.js实现一个简单的画布,可以绘制矩形和箭头。思路每一个图形包括:绘制的类型、起点的x坐标、起点的y坐标、宽、高。调用rough的generator()函数传入图形信息进行绘制,其中对于箭头需要进一步处理:根据宽高确定终点,并且定义角度等生......
  • React 类组件的生命周期
    React类组件的生命周期可以分成三个阶段:挂载(Mounting)阶段:当组件实例被创建并插入DOM中时,会调用的方法。更新(Updating)阶段:当组件的props或state发生变化时会调用的方法。卸载(Unmounting)阶段:当组件从DOM中移除时会调用的方法。以下是每个阶段典型的生命......
  • 【React系列三】—React学习历程的分享
    一、组件实例核心—Refs通过定义ref属性可以给标签添加标识字符串形式的Refs这种形式已经不再推荐使用,官方不建议使用https://zh-hans.legacy.reactjs.org/docs/refs-and-the-dom.html#legacy-api-string-refs回调形式的Refs<scripttype="text/babel">classDemoe......
  • EAS_WEB如何查找点击前台按钮后,调用的后台方法,
    第一种方法:正常有说明的可以直接从后台实现找到第二种方法,找不到的,类似如下,我们可以通过debugger的方式,找到对应的实现,具体路径org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping#registerHandlerMethod,没有registerHandlerMethod方法的话,可......
  • 网站后台地址修改?
    备份现有配置在进行任何修改之前,确保对现有的配置文件进行备份,以防修改过程中出现错误导致网站无法正常运行。定位配置文件找到包含后台地址的配置文件。这通常是 config.php 或者类似的文件,具体位置和名称取决于所使用的CMS或框架。编辑配置文件使用文本编辑器......
  • ReactOS寻找病返回最小StartingAddress所在结点。
    ReactOS寻找病返回最小StartingAddress所在结点。MmIterateFirstNode()函数文章目录ReactOS寻找病返回最小StartingAddress所在结点。MmIterateFirstNodeMmIterateFirstNode/*INCLUDES*****************************************************************/#incl......
  • ReactOS系统中MM_REGION结构体的声明
    ReactOS系统中MM_REGION结构体的声明ReactOS系统中MM_REGION结构体的声明文章目录ReactOS系统中MM_REGION结构体的声明MM_REGIONMM_REGIONtypedefstruct_MM_REGION{ULONGType;//MEM_COMMIT,MEM_RESERVEULONGProtect;//PAGE_READONLYY,PAGE_READ_WR......
  • ReactOS系统中EPROCESS结构体的声明
    ReactOS系统中EPROCESS结构体的声明ReactOS系统中EPROCESS结构体的声明文章目录ReactOS系统中EPROCESS结构体的声明EPROCESSEPROCESS////ExecutiveProcess(EPROCESS)//typedefstruct_EPROCESS{KPROCESSPcb;EX_PUSH_LOCKProcessLock;LA......
  • PbootCMS找回后台密码教程
    访问数据库管理工具使用phpMyAdmin或其他数据库管理工具,登录到你的数据库。找到用户表导航到PbootCMS数据库,找到用户表(通常名为 pboot_users)。修改密码找到管理员用户的记录,通常用户名为 admin。修改 password 字段。你可以使用MD5加密工具生成一个新......
  • 解决主机登录后台验证码不显示或访问乱码的问题
    启用PHP输出缓冲区登录主机面板。导航至PHP设置或配置文件管理。找到 php.ini 文件并编辑。启用输出缓冲区,确保以下配置项已设置:ini output_buffering=On保存 php.ini 文件。重启服务器保存配置后,重启Web服务器以使更改生效。如果使用的是......