当前位置: 首页 > news >正文

React从基础入门到高级实战:React 核心技术 - 表单处理与验证深度指南

React 表单处理与验证深度指南

在现代 Web 应用中,表单是用户与应用交互的核心方式之一。无论是注册、登录、结账还是数据提交,表单都扮演着至关重要的角色。React 作为一款流行的前端框架,提供了多种处理表单的工具和方法,帮助开发者构建高效、用户友好的表单体验。

本文专为需要处理用户输入的开发者设计,旨在帮助你全面掌握 React 中的表单处理与验证技术。我们将从基础概念讲起,逐步深入到高级实践,包括受控组件与非受控组件、表单验证、动态表单、错误处理与用户反馈等内容。通过一个用户注册表单案例和一个多步骤结账流程表单练习,你将学会如何高效地管理表单状态和验证用户输入。此外,我们将特别推荐 React Hook Form,并深入探讨其性能优势。

文章内容通俗易懂,同时保持深度和丰富性,包含大量代码示例和实践案例,适合希望系统学习 React 表单开发的开发者。


1. 引言

表单是 Web 应用中不可或缺的组成部分,承担着用户数据收集、验证和提交的重要任务。在传统的 HTML 中,表单处理依赖 DOM 的原生行为,而在 React 中,表单管理与组件状态紧密结合,提供了更高的灵活性和控制力。

React 中的表单处理主要分为受控组件非受控组件两种方式,每种方式都有其独特的优势和适用场景。此外,随着应用的复杂性增加,表单验证、动态字段管理和错误处理成为开发者必须掌握的关键技能。本文将通过理论讲解、代码示例和实践案例,带你逐步掌握这些技术。

我们还将重点介绍 React Hook Form,一个轻量、高效的表单管理库,它通过非受控组件的方式减少渲染开销,成为现代 React 开发的首选工具。无论你是初学者还是有经验的开发者,本文都将为你提供实用的指导和深入的洞察。


2. 受控组件与非受控组件

在 React 中,表单元素(如 <input><textarea><select>)的管理方式与传统 HTML 有所不同。React 提供了两种主要方法:受控组件非受控组件。理解它们的区别和应用场景是掌握 React 表单处理的第一步。

2.1 受控组件

受控组件是指表单元素的值由 React 的状态(state)控制。开发者通过 state 设置表单的值,并通过事件处理函数更新 state,实现数据的单向流动。

特点
  • 表单元素的值与 React 的 state 保持同步。
  • 每次用户输入都会触发状态更新和组件重新渲染。
  • 适合需要实时验证或动态交互的场景。
代码示例

以下是一个简单的受控输入框示例:

import { useState } from 'react';function ControlledInput() {const [value, setValue] = useState('');const handleChange = (event) => {setValue(event.target.value);};return (<div><label>受控输入</label><inputtype="text"value={value}onChange={handleChange}placeholder="请输入内容"/><p>当前值: {value}</p></div>);
}
  • value={value}:将输入框的值绑定到 state。
  • onChange={handleChange}:监听输入变化并更新 state。
优势
  • 实时控制:可以立即获取和验证用户输入。
  • 动态行为:易于实现条件渲染、表单联动等功能。
  • 一致性:与 React 的数据驱动理念高度契合。
注意事项
  • 频繁的状态更新可能导致性能问题,尤其是在大型表单中。
  • 需要为每个表单字段定义 state 和事件处理函数。

2.2 非受控组件

非受控组件是指表单元素的值由 DOM 自身管理,React 不直接控制其状态。开发者通过 ref 获取 DOM 元素的值。

特点
  • 表单数据存储在 DOM 中,与传统 HTML 表单行为类似。
  • 不需要为每个字段维护 state,减少渲染开销。
  • 适合简单表单或性能敏感的场景。
代码示例

以下是一个非受控输入框示例:

import { useRef } from 'react';function UncontrolledInput() {const inputRef = useRef(null);const handleSubmit = () => {alert(`输入值: ${inputRef.current.value}`);};return (<div><label>非受控输入</label><inputtype="text"ref={inputRef}placeholder="请输入内容"/><button onClick={handleSubmit}>提交</button></div>);
}
  • ref={inputRef}:通过 ref 引用 DOM 节点。
  • inputRef.current.value:在需要时获取输入值。
优势
  • 性能更高:无需频繁更新 state 和重新渲染。
  • 简单直接:代码量少,接近原生 HTML 表单。
注意事项
  • 不适合需要实时验证的场景。
  • 数据获取依赖手动操作,灵活性较低。

2.3 对比与选择

特性受控组件非受控组件
状态管理由 React state 管理由 DOM 管理
数据同步实时同步按需获取
性能可能频繁渲染渲染开销小
验证易于实时验证通常提交时验证
适用场景复杂表单、动态交互简单表单、性能敏感
选择建议
  • 受控组件:推荐用于大多数场景,特别是需要实时验证、动态字段或复杂交互的表单。
  • 非受控组件:适用于简单的静态表单或性能要求极高的应用。

3. 表单验证

表单验证是确保用户输入数据有效性、完整性和安全性的重要环节。在 React 中,开发者可以手动编写验证逻辑,但这往往繁琐且难以维护。借助现代工具如 React Hook FormYup,我们可以更高效地实现表单验证。

3.1 React Hook Form 简介

React Hook Form 是一个轻量、高性能的表单管理库,专为 React 函数组件设计。它通过 Hook API 提供表单状态管理、验证和提交功能,极大简化了开发流程。

核心优势
  • 性能优越:基于非受控组件,减少不必要的渲染。
  • 简洁 API:易于学习和集成。
  • 灵活验证:支持多种验证库(如 Yup、Zod)。
  • 动态支持:轻松处理动态字段。
安装
npm install react-hook-form

3.2 基本使用

以下是一个简单的表单示例,使用 React Hook Form 实现基础验证:

import { useForm } from 'react-hook-form';function SimpleForm() {const { register, handleSubmit, formState: { errors } } = useForm();const onSubmit = (data) => {console.log('表单数据:', data);};return (<div><label>用户名</label><input {...register('username', { required: '用户名必填' })} />{errors.username && <p>{errors.username.message}</p>}<label>密码</label><input type="password" {...register('password', { required: '密码必填' })} />{errors.password && <p>{errors.password.message}</p>}<button onClick={handleSubmit(onSubmit)}>提交</button></div>);
}
  • useForm():初始化表单管理。
  • register('fieldName'):注册表单字段并定义验证规则。
  • handleSubmit(onSubmit):处理表单提交。
  • errors:访问验证错误信息。

3.3 结合 Yup 实现复杂验证

Yup 是一个强大的模式验证库,通过声明式规则定义复杂的验证逻辑,与 React Hook Form 无缝集成。

安装
npm install yup @hookform/resolvers
示例:带验证的注册表单
import { useForm } from 'react-hook-form';
import { yupResolver } from '@hookform/resolvers/yup';
import * as yup from 'yup';const schema = yup.object().shape({username: yup.string().required('用户名必填').min(3, '至少 3 个字符'),email: yup.string().email('无效的邮箱').required('邮箱必填'),password: yup.string().required('密码必填').min(6, '至少 6 个字符'),
});function ValidatedForm() {const { register, handleSubmit, formState: { errors } } = useForm({resolver: yupResolver(schema),});const onSubmit = (data) => {console.log('表单数据:', data);};return (<div><label>用户名</label><input {...register('username')} />{errors.username && <p>{errors.username.message}</p>}<label>邮箱</label><input {...register('email')} />{errors.email && <p>{errors.email.message}</p>}<label>密码</label><input type="password" {...register('password')} />{errors.password && <p>{errors.password.message}</p>}<button onClick={handleSubmit(onSubmit)}>提交</button></div>);
}
  • yup.object().shape():定义验证规则。
  • yupResolver(schema):将 Yup 集成到 React Hook Form。
  • 错误信息通过 errors.fieldName.message 显示。
高级验证

Yup 支持条件验证、自定义规则等。例如,验证密码和确认密码是否一致:

const schema = yup.object().shape({password: yup.string().required('密码必填').min(6, '至少 6 个字符'),confirmPassword: yup.string().oneOf([yup.ref('password'), null], '密码不一致').required('确认密码必填'),
});

4. 动态表单

动态表单允许用户根据需要添加或删除表单字段,例如输入多个地址或教育经历。这种功能在复杂表单中非常常见。

4.1 使用 useFieldArray

React Hook Form 提供了 useFieldArray Hook,专门用于管理动态字段数组。

示例:动态地址字段
import { useForm, useFieldArray } from 'react-hook-form';function DynamicForm() {const { control, register, handleSubmit } = useForm({defaultValues: { addresses: [{ address: '' }] },});const { fields, append, remove } = useFieldArray({control,name: 'addresses',});const onSubmit = (data) => {console.log('表单数据:', data);};return (<div><h2>地址</h2>{fields.map((field, index) => (<div key={field.id}><input{...register(`addresses.${index}.address`, { required: '地址必填' })}placeholder="地址"/><button type="button" onClick={() => remove(index)}>删除</button></div>))}<button type="button" onClick={() => append({ address: '' })}>添加地址</button><button onClick={handleSubmit(onSubmit)}>提交</button></div>);
}
  • useFieldArray:管理动态字段。
  • append:添加新字段。
  • remove:删除指定字段。
  • register(addresses.${index}.address):注册动态字段。
验证动态字段

结合 Yup 验证动态字段:

const schema = yup.object().shape({addresses: yup.array().of(yup.object().shape({address: yup.string().required('地址必填'),})),
});

5. 错误处理与用户反馈

良好的错误处理和用户反馈是提升表单体验的关键。React Hook Form 提供了灵活的错误管理和反馈机制。

5.1 显示错误信息

通过 formState.errors 访问错误:

<input {...register('username', { required: '用户名必填' })} />
{errors.username && <p>{errors.username.message}</p>}

5.2 自定义反馈

  • 实时反馈:通过 mode: 'onChange' 启用实时验证。
const { register, formState: { errors } } = useForm({ mode: 'onChange' });
  • 表单级错误:提交时显示所有错误。
  • 焦点管理:使用 setFocus 将焦点移到错误字段。

5.3 用户友好建议

  • 使用颜色(如红色)高亮错误。
  • 提供清晰的错误消息。
  • 支持无障碍(ARIA 属性)。

6. 案例:用户注册表单

以下是一个完整的用户注册表单,支持验证和动态地址字段。

import { useForm, useFieldArray } from 'react-hook-form';
import { yupResolver } from '@hookform/resolvers/yup';
import * as yup from 'yup';const schema = yup.object().shape({username: yup.string().required('用户名必填').min(3, '至少 3 个字符'),email: yup.string().email('无效的邮箱').required('邮箱必填'),password: yup.string().required('密码必填').min(6, '至少 6 个字符'),addresses: yup.array().of(yup.object().shape({address: yup.string().required('地址必填'),})),
});function RegisterForm() {const { register, control, handleSubmit, formState: { errors } } = useForm({resolver: yupResolver(schema),defaultValues: { addresses: [{ address: '' }] },});const { fields, append, remove } = useFieldArray({control,name: 'addresses',});const onSubmit = (data) => {console.log('注册成功:', data);};return (<div><label>用户名</label><input {...register('username')} />{errors.username && <p>{errors.username.message}</p>}<label>邮箱</label><input {...register('email')} />{errors.email && <p>{errors.email.message}</p>}<label>密码</label><input type="password" {...register('password')} />{errors.password && <p>{errors.password.message}</p>}<h3>地址</h3>{fields.map((field, index) => (<div key={field.id}><input{...register(`addresses.${index}.address`)}placeholder="地址"/><button type="button" onClick={() => remove(index)}>删除</button>{errors.addresses?.[index]?.address && (<p>{errors.addresses[index].address.message}</p>)}</div>))}<button type="button" onClick={() => append({ address: '' })}>添加地址</button><button onClick={handleSubmit(onSubmit)}>注册</button></div>);
}
关键点
  • 使用 Yup 定义多层验证。
  • useFieldArray 管理动态字段。
  • 实时错误反馈提升体验。

7. 练习:多步骤表单

实现一个多步骤结账流程表单,包含以下步骤:

  1. 填写地址
  2. 选择支付方式
  3. 确认订单

实现思路

  • 使用 state 管理当前步骤。
  • 每个步骤为独立组件。
  • React Hook Form 管理整个表单状态。

参考代码

import { useForm, FormProvider } from 'react-hook-form';
import { useState } from 'react';function Step1({ nextStep }) {const { register, formState: { errors } } = useForm();return (<div><h3>步骤 1: 填写地址</h3><input {...register('address', { required: '地址必填' })} />{errors.address && <p>{errors.address.message}</p>}<button onClick={nextStep}>下一步</button></div>);
}function Step2({ nextStep, prevStep }) {const { register, formState: { errors } } = useForm();return (<div><h3>步骤 2: 选择支付方式</h3><select {...register('payment', { required: '请选择支付方式' })}><option value="">请选择</option><option value="credit">信用卡</option><option value="paypal">PayPal</option></select>{errors.payment && <p>{errors.payment.message}</p>}<button onClick={prevStep}>上一步</button><button onClick={nextStep}>下一步</button></div>);
}function Step3({ prevStep, onSubmit }) {return (<div><h3>步骤 3: 确认订单</h3><p>请确认您的订单信息。</p><button onClick={prevStep}>上一步</button><button onClick={onSubmit}>提交订单</button></div>);
}function MultiStepForm() {const methods = useForm();const [step, setStep] = useState(1);const nextStep = () => setStep(step + 1);const prevStep = () => setStep(step - 1);const onSubmit = (data) => {console.log('订单数据:', data);alert('订单已提交');};return (<FormProvider {...methods}>{step === 1 && <Step1 nextStep={nextStep} />}{step === 2 && <Step2 nextStep={nextStep} prevStep={prevStep} />}{step === 3 && <Step3 prevStep={prevStep} onSubmit={methods.handleSubmit(onSubmit)} />}</FormProvider>);
}

8. React Hook Form 的性能优势

React Hook Form 的核心优势在于其基于非受控组件的实现方式,避免了传统受控组件的频繁渲染问题。

8.1 为什么性能更好?

  • 减少渲染:仅在必要时更新 DOM。
  • 无状态管理开销:无需为每个字段维护 state。
  • 高效事件处理:通过 ref 管理表单数据。

8.2 与其他库的对比

与 Formik 等库相比,React Hook Form 在大型表单中渲染次数显著减少。例如:

  • Formik:每个输入变化触发整个表单重新渲染。
  • React Hook Form:仅更新相关字段。

8.3 数据支持

根据官方性能测试,React Hook Form 在复杂表单中的渲染次数可减少 50%-70%(具体数据见官方文档)。


9. 总结与进阶建议

本文系统介绍了 React 中的表单处理与验证技术,从受控与非受控组件的基础知识,到 React Hook Form 和 Yup 的高级应用,再到动态表单和多步骤表单的实践案例,内容全面且实用。

总结

  • 受控组件适合复杂交互,非受控组件适合简单场景。
  • React Hook Form 是高效表单管理的首选工具。
  • 结合 Yup 可以轻松实现复杂验证。
  • 动态表单和多步骤表单提升了用户体验。

进阶建议

  • 探索 React Hook Form 的 useWatchuseFormContext
  • 学习 Yup 的条件验证和自定义规则。
  • 在实际项目中实践多步骤表单设计。

掌握本文内容后,你将能够自信地处理任何表单需求,并构建高效、用户友好的 React 应用。


附代码:

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>React 表单处理与验证深度指南</title><script src="https://cdn.jsdelivr.net/npm/react@18/umd/react.development.js"></script><script src="https://cdn.jsdelivr.net/npm/react-dom@18/umd/react-dom.development.js"></script><script src="https://cdn.jsdelivr.net/npm/@babel/standalone/babel.min.js"></script><script src="https://cdn.jsdelivr.net/npm/react-hook-form@7/dist/index.umd.min.js"></script><script src="https://cdn.jsdelivr.net/npm/yup@1/dist/yup.umd.min.js"></script><script src="https://cdn.jsdelivr.net/npm/@hookform/resolvers@3/dist/umd/index.min.js"></script><link href="https://cdn.jsdelivr.net/npm/tailwindcss@2/dist/tailwind.min.css" rel="stylesheet">
</head>
<body class="bg-gray-100 p-6"><div id="root" class="max-w-4xl mx-auto bg-white p-6 rounded-lg shadow-md"></div><script type="text/babel">const { useState, useForm, useFieldArray, FormProvider } = ReactHookForm;const { yupResolver } = HookFormResolvers;const yup = window.yup;// 受控组件示例function ControlledInput() {const [value, setValue] = useState('');const handleChange = (e) => setValue(e.target.value);return (<div className="mb-4"><label className="block text-gray-700">受控输入</label><inputtype="text"value={value}onChange={handleChange}placeholder="请输入内容"className="mt-1 p-2 border rounded w-full"/><p className="mt-2 text-gray-600">当前值: {value}</p></div>);}// 非受控组件示例function UncontrolledInput() {const inputRef = React.useRef(null);const handleSubmit = () => alert(`输入值: ${inputRef.current.value}`);return (<div className="mb-4"><label className="block text-gray-700">非受控输入</label><inputtype="text"ref={inputRef}placeholder="请输入内容"className="mt-1 p-2 border rounded w-full"/><buttononClick={handleSubmit}className="mt-2 bg-blue-500 text-white p-2 rounded">提交</button></div>);}// 带验证的简单表单function SimpleForm() {const { register, handleSubmit, formState: { errors } } = useForm();const onSubmit = (data) => console.log('表单数据:', data);return (<div className="mb-4"><label className="block text-gray-700">用户名</label><input{...register('username', { required: '用户名必填' })}className="mt-1 p-2 border rounded w-full"/>{errors.username && <p className="text-red-500">{errors.username.message}</p>}<label className="block text-gray-700 mt-2">密码</label><inputtype="password"{...register('password', { required: '密码必填' })}className="mt-1 p-2 border rounded w-full"/>{errors.password && <p className="text-red-500">{errors.password.message}</p>}<buttononClick={handleSubmit(onSubmit)}className="mt-2 bg-blue-500 text-white p-2 rounded">提交</button></div>);}// 用户注册表单const schema = yup.object().shape({username: yup.string().required('用户名必填').min(3, '至少 3 个字符'),email: yup.string().email('无效的邮箱').required('邮箱必填'),password: yup.string().required('密码必填').min(6, '至少 6 个字符'),addresses: yup.array().of(yup.object().shape({address: yup.string().required('地址必填'),})),});function RegisterForm() {const { register, control, handleSubmit, formState: { errors } } = useForm({resolver: yupResolver(schema),defaultValues: { addresses: [{ address: '' }] },});const { fields, append, remove } = useFieldArray({control,name: 'addresses',});const onSubmit = (data) => console.log('注册成功:', data);return (<div className="mb-4"><label className="block text-gray-700">用户名</label><input{...register('username')}className="mt-1 p-2 border rounded w-full"/>{errors.username && <p className="text-red-500">{errors.username.message}</p>}<label className="block text-gray-700 mt-2">邮箱</label><input{...register('email')}className="mt-1 p-2 border rounded w-full"/>{errors.email && <p className="text-red-500">{errors.email.message}</p>}<label className="block text-gray-700 mt-2">密码</label><inputtype="password"{...register('password')}className="mt-1 p-2 border rounded w-full"/>{errors.password && <p className="text-red-500">{errors.password.message}</p>}<h3 className="mt-4 text-lg font-semibold">地址</h3>{fields.map((field, index) => (<div key={field.id} className="flex items-center mt-2"><input{...register(`addresses.${index}.address`)}placeholder="地址"className="p-2 border rounded w-full"/><buttontype="button"onClick={() => remove(index)}className="ml-2 bg-red-500 text-white p-2 rounded">删除</button>{errors.addresses?.[index]?.address && (<p className="text-red-500">{errors.addresses[index].address.message}</p>)}</div>))}<buttontype="button"onClick={() => append({ address: '' })}className="mt-2 bg-green-500 text-white p-2 rounded">添加地址</button><buttononClick={handleSubmit(onSubmit)}className="mt-4 bg-blue-500 text-white p-2 rounded">注册</button></div>);}// 多步骤表单function Step1({ nextStep }) {const { register, formState: { errors } } = useForm();return (<div><h3 className="text-lg font-semibold">步骤 1: 填写地址</h3><input{...register('address', { required: '地址必填' })}className="mt-1 p-2 border rounded w-full"/>{errors.address && <p className="text-red-500">{errors.address.message}</p>}<buttononClick={nextStep}className="mt-2 bg-blue-500 text-white p-2 rounded">下一步</button></div>);}function Step2({ nextStep, prevStep }) {const { register, formState: { errors } } = useForm();return (<div><h3 className="text-lg font-semibold">步骤 2: 选择支付方式</h3><select{...register('payment', { required: '请选择支付方式' })}className="mt-1 p-2 border rounded w-full"><option value="">请选择</option><option value="credit">信用卡</option><option value="paypal">PayPal</option></select>{errors.payment && <p className="text-red-500">{errors.payment.message}</p>}<buttononClick={prevStep}className="mt-2 bg-gray-500 text-white p-2 rounded mr-2">上一步</button><buttononClick={nextStep}className="mt-2 bg-blue-500 text-white p-2 rounded">下一步</button></div>);}function Step3({ prevStep, onSubmit }) {return (<div><h3 className="text-lg font-semibold">步骤 3: 确认订单</h3><p>请确认您的订单信息。</p><buttononClick={prevStep}className="mt-2 bg-gray-500 text-white p-2 rounded mr-2">上一步</button><buttononClick={onSubmit}className="mt-2 bg-blue-500 text-white p-2 rounded">提交订单</button></div>);}function MultiStepForm() {const methods = useForm();const [step, setStep] = useState(1);const nextStep = () => setStep(step + 1);const prevStep = () => setStep(step - 1);const onSubmit = (data) => {console.log('订单数据:', data);alert('订单已提交');};return (<FormProvider {...methods}>{step === 1 && <Step1 nextStep={nextStep} />}{step === 2 && <Step2 nextStep={nextStep} prevStep={prevStep} />}{step === 3 && <Step3 prevStep={prevStep} onSubmit={methods.handleSubmit(onSubmit)} />}</FormProvider>);}// 主应用function App() {return (<div><h1 className="text-3xl font-bold mb-6">React 表单处理与验证深度指南</h1><h2 className="text-2xl font-semibold mb-4">受控组件示例</h2><ControlledInput /><h2 className="text-2xl font-semibold mb-4">非受控组件示例</h2><UncontrolledInput /><h2 className="text-2xl font-semibold mb-4">简单表单示例</h2><SimpleForm /><h2 className="text-2xl font-semibold mb-4">用户注册表单</h2><RegisterForm /><h2 className="text-2xl font-semibold mb-4">多步骤表单</h2><MultiStepForm /></div>);}ReactDOM.render(<App />, document.getElementById('root'));</script>
</body>
</html>

这篇指南通过理论与实践相结合,帮助你从基础到高级掌握 React 表单处理技术。希望对你有所帮助!如果有任何问题或改进建议,请随时告诉我。

http://www.xdnf.cn/news/658891.html

相关文章:

  • 关于模型记忆力的实现方式
  • Linux GPIO子系统深度解析:从历史演进到实战应用
  • 使用 Pfam 和 InterProScan 进行蛋白质家族和功能域的分析
  • 第一章:MLOps/LLMOps 导论:原则、生命周期与挑战
  • 激光开卷落料线:技术革新与产业应用综述
  • PCCW Global 与银河航天在港成功完成低轨卫星测试
  • 紫光同创FPGA实现视频采集转USB2.0输出,基于CY7C68013芯片,提供PDS工程源码和技术支持和QT上位机
  • DC-DC升压
  • 【Qt】Debug版本正常运行,Release版本运行卡死
  • FreeRTOS 事件标志组详解:原理、用法与实战技巧
  • 网页模板素材网站 web前端网页制作模板
  • 如何清除浏览器启动hao点360
  • 【多智能体系统开发框架AutoGen解析与实践】
  • 初学ADC
  • 【四】频率域滤波(下)【830数字图像处理】
  • 华为OD机试真题——通信系统策略调度(用户调度问题)(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
  • 算力服务器和GPU服务器之间的联系
  • C++中使用类的继承机制来定义和实现基类与派生类
  • 初始化硬盘时,选MBR还是GUID?—「小白教程」
  • Linux系统中为Qt项目封装一个udp客户端类
  • 在麒麟系统(Kylin OS)上安装`geckodriver`
  • 跳板问题(贪心算法+细节思考)
  • 中国工程咨询协会新型基础设施专业委员会成立
  • Open vSwitch笔记20250526
  • 基于python合成100X100的透明背景图片和图标
  • 十大排序算法
  • 单例模式,饿汉式,懒汉式,在java和spring中的体现
  • 从数据页角度理解B+树查询
  • Netty学习专栏(五):Netty高性能揭秘(Reactor模式与零拷贝的深度实践)
  • 华为OD机试真题——单词接龙(首字母接龙)(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现