JS里在光标位置插入字符

博客展示了一段Javascript代码,定义了AddOnPos函数用于在输入框指定位置插入字符。代码包含获取光标位置和插入字符的操作,但博主表示未完全理解代码,希望有高人给予解释。

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

None.gif<script language=Javascript>
None.gif
function AddOnPos(obj, charvalue)
None.gif{
None.gif    
//obj代表要插入字符的输入框
None.gif
    //value代表要插入的字符
None.gif
    
None.gif    obj.focus();
None.gif    
var r = document.selection.createRange();
None.gif    
var ctr = obj.createTextRange();
None.gif    
var i;
None.gif    
var s = obj.value;
None.gif    
None.gif    
//注释掉的这种方法只能用在单行的输入框input内
None.gif
    //对多行输入框textarea无效
None.gif
    //r.setEndPoint("StartToStart", ctr);
None.gif
    //i = r.text.length;
None.gif
    //取到光标位置----Start----
None.gif
    var ivalue = "&^asdjfls2FFFF325%$^&"
None.gif    r.text 
= ivalue;
None.gif    i 
= obj.value.indexOf(ivalue);
None.gif    r.moveStart(
"character"-ivalue.length);
None.gif    r.text 
= "";
None.gif    
//取到光标位置----End----
None.gif
    //插入字符
None.gif
    obj.value = s.substr(0,i) + charvalue + s.substr(i,s.length);
None.gif    ctr.collapse(
true);
None.gif    ctr.moveStart(
"character", i + charvalue.length);
None.gif    ctr.select();
None.gif}
None.gif
</script>

虽然可以实现功能,但是没有完全看明白
希望哪位高人可以给解释一下
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值