我使用的是带有预填充值的输入型文本框,当我单击输入框时,光标的位置会移动到开头,这在其他浏览器中是不会发生的(只有IE11才是问题所在)。这是非常烦人的,并且花了几个小时调试。事实上,在IE中调试是非常痛苦的。
请注意,我不想操作DOM,我们也不打算在应用程序中再使用Jquery。
我使用react Js作为UI框架。
如果有人在这方面给点提示,那就太好了。
发布于 2020-09-30 00:45:49
您将需要:
上的输入元素
onFocus
事件处理程序的反应引用获得这两个值后,需要将选择范围设置为与初始值相同的长度,如下所示:
// either
const inputRef = useRef();
// or
const inputRef = React.createRef()
const onFocus = () => {
inputRef.current.setSelectionRange(value, value);
}
<input ref={inputRef} value={value} onFocus={onFocus}/>
setSelectionRange(startRange, endRange)
-传递给这两个值的长度相同会将光标推到值的末尾,而不会选择任何内容。
发布于 2018-10-10 15:01:59
尝试使用value属性来设置预填充值。代码如下:
<input type="text" id="txtinput" value="default value" />
测试结果如下:
IE浏览器版本如下:
https://stackoverflow.com/questions/52725271
复制相似问题