在 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:根据失去焦点时保存的光标位置,将指定的内容插入到该位置。
相关推荐
gqkmiss几秒前
Chrome 浏览器插件获取网页 iframe 中的 window 对象
前端·chrome·iframe·postmessage·chrome 插件
m0_748247552 小时前
Web 应用项目开发全流程解析与实战经验分享
开发语言·前端·php
m0_748255023 小时前
前端常用算法集合
前端·算法
真的很上进3 小时前
如何借助 Babel+TS+ESLint 构建现代 JS 工程环境?
java·前端·javascript·css·react.js·vue·html
web130933203983 小时前
vue elementUI form组件动态添加el-form-item并且动态添加rules必填项校验方法
前端·vue.js·elementui
NiNg_1_2343 小时前
Echarts连接数据库,实时绘制图表详解
前端·数据库·echarts
如若1234 小时前
对文件内的文件名生成目录,方便查阅
java·前端·python
滚雪球~5 小时前
npm error code ETIMEDOUT
前端·npm·node.js
沙漏无语5 小时前
npm : 无法加载文件 D:\Nodejs\node_global\npm.ps1,因为在此系统上禁止运行脚本
前端·npm·node.js
supermapsupport5 小时前
iClient3D for Cesium在Vue中快速实现场景卷帘
前端·vue.js·3d·cesium·supermap