js 鼠标单击多行文本框时怎样将光标定在文本框最前面

本文介绍了一种使用JavaScript实现文本区域中光标定位的方法,适用于不同浏览器环境。通过检测浏览器特性选择合适的方式进行光标位置设定。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

例子:
<!doctype html>
<html lang="en">
 <head>
  <meta charset="UTF-8">
  <meta name="Generator" content="EditPlus®">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
  <title>Document</title>
 </head>
 <script type="text/javascript">
	function locateCursor(elem, index) {
		if (elem.setSelectionRange) {
			elem.setSelectionRange(index, index);
		} else {
			var range = elem.createTextRange();
			var len = elem.value.length;
			range.moveStart('character', -len);
			range.moveEnd('character', -len);
			range.moveStart('character', index);
			range.moveEnd('character', 0);
			range.select();
		}
	}
 </script>
 <body>
  <textarea rows="40" cols="100" onclick="locateCursor(this, 0)">走过红尘的纷扰,弹落灵魂沾染的尘埃,携一抹淡淡的情怀,迎着清馨的微风,坐在岁月的源头,看时光婆娑的舞步,让自己安静在时间的沙漏里,感受淡如清风,静若兰的唯美。——题记
  仰卧在大自然的摇篮里,枕着岁月的臂弯,依着时光的轻柔,心漫步在淡淡的微风里,把过往凝聚成一朵花的淡雅,好比空谷幽兰的静美</textarea>
 </body>
</html>

// elemdom元素index需要光标移动位置(文本始处0)
function locateCursor(elem, index) {
if (elem.setSelectionRange) {
elem.setSelectionRange(index, index);
} else {
var range = elem.createTextRange();
var len = elem.value.length;
range.moveStart('character', -len);
range.moveEnd('character', -len);
range.moveStart('character', index);
range.moveEnd('character', 0);
range.select();
}
}

eg:



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值