javascript - 类型 'selectionStart' 上不存在属性 'EventTarget'

标签 javascript reactjs typescript material-ui

我正在使用 selectionStartselectionEnd为了获得文本选择的起点和终点。
代码:https://codesandbox.io/s/busy-gareth-mr04o
但是,我正在努力定义可以调用它们的事件的类型。
如果我使用 any ,代码可以正常工作,但我更愿意知道正确的事件。
我尝试了这些类型:ElementReact.SyntheticEvent<HTMLDivElement><HTMLDivElement>没有运气

export default function App() {
  const [startText, setStartText] = useState<number | undefined>();
  const [endText, setEndText] = useState<number | undefined>();

  const handleOnSelect = (event: any) => { <--- I CANNOT FIND THE RIGHT EVENT TYPE
    setStartText(event.target.selectionStart);
    setEndText(event.target.selectionEnd);
  };

  return (
    <Grid container direction="column" className="App">
      You can type here below:
      <TextField
        value={"This is a example, select a word from this string"}
        onSelect={(event) => handleOnSelect(event)}
      />
      <br />
      <Grid item>The selected word starts at character: {startText}</Grid>
      <Grid item>The selected word ends at character: {endText}</Grid>
    </Grid>
  );
}

最佳答案

这是一个棘手的问题,因为 material-ui TextField组件涉及多个嵌套节点。传递给 onSelect 的参数函数是 div .然而,事件本身发生在 input里面div .

const handleOnSelect = (event: React.SyntheticEvent<HTMLDivElement, Event>) => {
    console.log(event.target, event.currentTarget);
};
这将记录 input然后是 div .
使用 event.currentTarget获取非常具体的 Typescript 信息。我们知道这是一个 HTMLDivElement .但是 div没有属性 selectionStartselectionEnd我们想要访问的。这些存在于input .event.target给我们一个非常模糊的类型 EventTarget .我们不知道目标是 input .
一种选择是在运行时验证元素。
const handleOnSelect = (event: React.SyntheticEvent<HTMLDivElement, Event>) => {
    if ( event.target instanceof HTMLInputElement ) {
        setStartText(event.target.selectionStart);
        setEndText(event.target.selectionEnd);
    }
};
因为您知道该事件将始终发生在 HTMLInputElement ,我认为做出断言是安全的。
const handleOnSelect = (event: React.SyntheticEvent<HTMLDivElement, Event>) => {
    const target = event.target as HTMLInputElement;
    setStartText(target.selectionStart);
    setEndText(target.selectionEnd);
};
请注意 selectionStartselectionEnd属性使用 null而不是 undefined .因此,您需要将状态类型更改为 <number | null>或替换 nullundefined通过使用空值合并 event.target.selectionStart ?? undefined .

关于javascript - 类型 'selectionStart' 上不存在属性 'EventTarget',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66710037/

相关文章:

javascript - 当不同跨度具有事件类时更改跨度的内容

javascript - 使用重定向规则的 Chrome 扩展 "Uncaught error: Invalid value"

javascript - ESLint 无法解析扩展的绝对文件路径

javascript - 重组 pure() 与 React.PureComponent

javascript - 如何处理条件组件内的 onClick 事件

arrays - typescript :声明返回嵌套数组的函数

javascript - 使用 AngularJS 和 PHP 将数据保存到数据库

javascript - react : Looping through an array within a state

javascript - 在类中封装验证方法(Angular)

typescript - TypeScript 的 Array.map 解构的 Rust 等价物是什么?