在 React 中,Input 失去焦点时获取失去焦点的位置并插入值

实现思路:

  1. 监听 Input 失去焦点 (onBlur) 事件 :在 onBlur 事件中,我们可以获取光标的当前位置以及 Input 中的值。
  2. 使用 onClickonMouseDown 事件来获取点击的其他位置:通过全局点击监听,获取点击的目标元素。
  3. 插入值到光标位置 :通过 DOM 的 selectionStartselectionEnd 来确定光标位置,进而插入新的值。

示例代码:

javascript 复制代码
import React, { useState, useRef } from 'react';

const InputWithInsert = () => {
  const [inputValue, setInputValue] = useState('');  // Input的值
  const inputRef = useRef(null);  // 引用 Input 组件
  const [focusPosition, setFocusPosition] = useState(null); // 光标位置

  // 监听 Input 的变化
  const handleInputChange = (e) => {
    setInputValue(e.target.value);
  };

  // 监听 Input 失去焦点时,记录光标位置
  const handleBlur = (e) => {
    const input = inputRef.current;
    if (input) {
      const cursorPosition = input.selectionStart;  // 获取失去焦点时的光标位置
      setFocusPosition(cursorPosition);
    }
  };

  // 插入值到光标位置
  const insertValueAtCursor = (value) => {
    const input = inputRef.current;
    if (input && focusPosition !== null) {
      const beforeCursor = inputValue.substring(0, focusPosition);
      const afterCursor = inputValue.substring(focusPosition);
      const newValue = beforeCursor + value + afterCursor;
      setInputValue(newValue);
    }
  };

  // 模拟点击插入值
  const handleClickInsert = () => {
    insertValueAtCursor('[插入内容]');  // 模拟插入内容
  };

  return (
    <div>
      <input
        type="text"
        value={inputValue}
        onChange={handleInputChange}
        onBlur={handleBlur}  // 监听失去焦点事件
        ref={inputRef}       // 引用 Input 组件
      />
      <button onClick={handleClickInsert}>插入值</button>
    </div>
  );
};

export default InputWithInsert;
  • inputRef :用来引用 <input> 元素,以便在失去焦点时获取光标位置。
  • handleBlur :在 Input 失去焦点时记录光标位置(使用 selectionStart 获取光标的位置)。
  • insertValueAtCursor:根据失去焦点时保存的光标位置,将指定的内容插入到该位置。
相关推荐
举个栗子dhy4 分钟前
解决在父元素上同时使用 onMouseEnter和 onMouseLeave时导致下拉菜单无法正常展开或者提前收起问题
前端·javascript·react.js
Coding_Doggy10 分钟前
苍穹外卖前端Day1 | vue基础、Axios、路由vue-router、状态管理vuex、TypeScript
前端
前端与小赵10 分钟前
vue3和vue2生命周期的区别
前端·javascript·vue.js
用户4582031531714 分钟前
10个你可能不知道的实用CSS技巧,立竿见影提升开发效率
前端·css
在逃牛马14 分钟前
【Uni-App+SSM+MP 宠物实战】Day4:Uni-App 项目初始化
前端
J_Asia15 分钟前
如何exclude不必要的so文件?
前端
一鹿有你们~17 分钟前
面试题-前端如何解决跨域
前端·javascript·跨域
文心快码BaiduComate21 分钟前
文心快码升级至3.5S版本,强化多智能体自协同能力
前端·后端·程序员
Sailing22 分钟前
👉 👉 Vue3 自定义 Hook:从入门到进阶(~~安静的阅读2分钟,相信我,这篇文章一定能给你启发)
前端·javascript·vue.js