如何在React中实现编辑框自动获取焦点与失焦更新功能

概述

在React应用中,编辑框的焦点控制和数据回填是一个常见需求。本文将介绍如何使用useRefuseEffect钩子,在组件中实现输入框自动获取焦点及失焦后更新数据的功能。

实现步骤
  1. 引入钩子 : 在组件中引入useEffectuseRef钩子。

  2. 创建引用 : 使用useRef创建一个引用(ref),并将其赋值给输入框的ref属性,以便能够访问输入框的DOM元素。

  3. 自动获取焦点 : 通过useEffect钩子监听isEditing状态。当isEditingtrue时,使用引用ref.current.focus()让输入框自动获取焦点。

  4. 失焦更新数据 : 在输入框的onBlur事件中,调用modifyTodoTitle(ref.current.value)函数,用于在输入框失去焦点时更新数据。

示例代码
javascript 复制代码
import React, { useEffect, useRef } from 'react';

function Editing({ todo }) {
  // 从 todo 对象中解构出 isEditing 状态和 modifyTodoTitle 函数
  const { isEditing, modifyTodoTitle } = todo;

  // 创建一个引用,用于访问输入框 DOM 元素
  const ref = useRef(null);

  // 使用 useEffect 钩子,在 isEditing 状态变为 true 时将焦点设置到输入框
  useEffect(() => {
    if (isEditing) {
      ref.current.focus();
    }
  }, [isEditing]);

  return (
    <input
      ref={ref}
      className="edit"
      defaultValue={todo.title} // 输入框显示待办事项的当前标题
      onBlur={() => modifyTodoTitle(ref.current.value)} // 当输入框失去焦点时,调用 modifyTodoTitle 更新标题
    />
  );
}

export default Editing;
功能描述

在上述代码中,Editing组件接收一个todo对象,其中包含待办事项的标题和编辑状态。使用useRef创建一个引用,这样在组件的整个生命周期内都可以持续访问相同的DOM元素。useEffect钩子确保在isEditing状态为true时,输入框能够自动获得焦点。此外,当用户完成编辑并点击其他地方导致输入框失去焦点时,onBlur事件触发,调用modifyTodoTitle函数来更新待办事项的标题。


English Version

How to Implement Auto-Focus and Data Backfilling for Edit Fields in React

Overview

Controlling focus and backfilling data in edit fields are common requirements in React applications. This article explains how to use the useRef and useEffect hooks to implement auto-focus for an input field and update data after it loses focus.

Implementation Steps
  1. Import Hooks : Import useEffect and useRef hooks in the component.

  2. Create a Reference : Use useRef to create a reference (ref) and assign it to the ref attribute of the input field to access the input field's DOM element.

  3. Auto-Focus : Utilize the useEffect hook to listen for changes in the isEditing state. When isEditing is true, use the reference ref.current.focus() to automatically focus the input field.

  4. Update Data on Blur : In the onBlur event of the input field, invoke the modifyTodoTitle(ref.current.value) function to update data when the input field loses focus.

Example Code
javascript 复制代码
import React, { useEffect, useRef } from 'react';

function Editing({ todo }) {
  // Destructure the isEditing state and the modifyTodoTitle function from the todo object
  const { isEditing, modifyTodoTitle } = todo;

  // Create a ref to access the input box DOM element
  const ref = useRef(null);

  // Use the useEffect hook to set focus to the input box when the isEditing state becomes true
  useEffect(() => {
    if (isEditing) {
      ref.current.focus();
    }
  }, [isEditing]);

  return (
    <input
      ref={ref}
      className="edit"
      defaultValue={todo.title} // Display the current title of the todo item in the input box
      onBlur={() => modifyTodoTitle(ref.current.value)} // Call modifyTodoTitle to update the title when the input box loses focus
    />
  );
}

export default Editing;
Feature Description

In the code above, the Editing component receives a todo object, which contains the title of the to-do item and its editing state. A reference is created using useRef, allowing continuous access to the same DOM element throughout the component's lifecycle. The useEffect hook ensures that the input field automatically receives focus when the isEditing state is true. Additionally, when the user finishes editing and clicks elsewhere causing the input field to lose focus, the onBlur event triggers, invoking the modifyTodoTitle function to update the title of the to-do item.

相关推荐
摘星编程1 小时前
OpenHarmony环境下React Native:DatePicker日期选择器
react native·react.js·harmonyos
橙露1 小时前
NNG通信框架:现代分布式系统的通信解决方案与应用场景深度分析
运维·网络·tcp/ip·react.js·架构
摘星编程1 小时前
用React Native开发OpenHarmony应用:Calendar日期范围选择
javascript·react native·react.js
摘星编程5 小时前
React Native鸿蒙:Tree节点选择状态
react native·react.js·harmonyos
摘星编程5 小时前
用React Native开发OpenHarmony应用:StickyHeader粘性标题
javascript·react native·react.js
Jack___Xue6 小时前
LangGraph学习笔记(六)---LangGraph ReAct应用
笔记·学习·react.js
●VON7 小时前
React Native for OpenHarmony:构建高性能、高体验的 TextInput 输入表单
javascript·学习·react native·react.js·von
●VON7 小时前
React Native for OpenHarmony:ActivityIndicator 动画实现详解
javascript·学习·react native·react.js·性能优化·openharmony
谢尔登8 小时前
React19事件调度的设计思路
前端·javascript·react.js
2301_796512528 小时前
【精通篇】打造React Native鸿蒙跨平台开发高级复合组件库开发系列:Lazyload 懒加载(懒加载的图片)
前端·javascript·react native·react.js·ecmascript·harmonyos