FF IE 得到input.text textarea 光标,更改光标位置 备忘

本文介绍了一种JavaScript函数,用于在用户输入过程中过滤掉特定字符,如< > /等,以防止潜在的安全问题,并提供了光标定位的实现细节。

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

function inputkeyup(obj,event,value){
if(event.keyCode!=37&&event.keyCode!=39&&event.keyCode!=46&&event.keyCode!=8){
newvalue=value.replace(/[<>]/g,'');
//如果输入错误,退格并且定位光标位置
if(value!=newvalue){
if(document.selection){
if(obj.type == 'textarea'){
var slen = 0;
var nlen = value.length-newvalue.length;
var sTextRange=document.selection.createRange();
var oTextRange = document.body.createTextRange();
oTextRange.moveToElementText(obj);
for (start=0; oTextRange.compareEndPoints("StartToStart", sTextRange) < 0; slen++){
oTextRange.moveStart('character', 1);
}
obj.value=newvalue;
var a =obj.createTextRange();
a.moveStart('character',slen-nlen);
a.collapse(true);
a.select();
}else{
var s=document.selection.createRange();
s.setEndPoint("StartToStart",obj.createTextRange());
var slen = s.text.length;
var nlen = value.length-newvalue.length;
obj.value=newvalue;
var a =obj.createTextRange();
a.moveStart('character',slen-nlen);
a.collapse(true);
a.select();
}
}else{
var slen = obj.selectionStart;
var nlen = value.length-newvalue.length;
obj.value=newvalue;
obj.selectionStart=slen-nlen;
obj.selectionEnd=slen-nlen;
}
}
}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值