当输入框聚焦时,我需要将光标(插入符号)设置为第一个位置:
我猜下面的代码应该是可行的,但实际上它并不能正常工作。不过,如果由按钮点击触发,则可以正常工作。
我做错了什么?
import React, { ChangeEventHandler, useRef, useState } from "react";
const setCaretPosition = (ctrl, pos) => {
// Modern browsers
if (ctrl.setSelectionRange) {
ctrl.focus();
ctrl.setSelectionRange(pos, pos);
}
};
export default function App() {
const [value,setValue] = useState("123456789");
const input_ref = useRef(null);
const onFocus = () => {
setCaretPosition(input_ref.current, 0);
};
const onChange = (event) => {
setValue(event.target.value);
};
const buttonClick = () => {
setCaretPosition(input_ref.current, 0);
};
return (
<React.Fragment>
<div>
<input
type="text"
onChange={onChange}
value={value}
ref={input_ref}
onFocus={onFocus}
/>
<button onClick={buttonClick}>Reset cursor</button>
</div>
</React.Fragment>
);
}
DD-MM-YYYY
的掩码存在。因此,我想确保光标在开头。在移动设备上通常很难选择掩码的确切开头。 - cbdeveloper