关于正则表达式的一个问题。。。。。。急用 easyui

<input name="uaddress"
id="uaddress"
class="easyui-validatebox"
style="width:180px"
required="true"
missingMessage="必填"
validType="length[1,200]"
onkeyup="value=value.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')">

红色部分的正则表达式,输入一个非法字符会自动去掉

但是焦点在最后一位,键盘的左右键不管用了

输入时一直处在最后一位,怎么解决这种情况






...全文
189 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
引用 8 楼 jiangbai333 的回复:
上面的 标签位置错了
<script>
function test(key) {
if((event.keyCode!=37)&&(event.keyCode!=38)&&(event.keyCode!=39)&&(event.keyCode!=40)){
   
     document.getElementById('uaddress').value=key.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')
    }
 
}
</script>


<input name="uaddress" 
 id="uaddress"
 class="easyui-validatebox"
 style="width:180px"
required="true" 
missingMessage="必填" 
validType="length[1,200]"
onkeyup="test(this.value)">
这个真的可行!!! 不过还有个问题 填入字符后把焦点移到中间 再输入正常字符,字符会加到最后面去 输入非法字符焦点还是会回到最后 能帮我再优化一下吗?
  • 打赏
  • 举报
回复
引用 6 楼 xzy21com 的回复:
onkeyup意思是每次敲键盘后都执行。而你又用this.value=this.value.replace()不断赋值,在IE下就造成光标一直在后面(firefox等不会),所以建议你改成离开焦点再执行。 <input name="uaddress" id="uaddress" class="easyui-validatebox" style="width:180px" required="true" missingMessage="必填" validType="length[1,200]" onblur="this.value=this.value.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')">
我试了一下,你这样,如果是非法字符就不能判断赋值空了,还是行不通
jiangbai333 2014-04-03
  • 打赏
  • 举报
回复
引用 7 楼 jiangbai333 的回复:
引用 4 楼 lesbian0826 的回复:
[quote=引用 2 楼 jiangbai333 的回复:] 你找一下左右键的编码 可能因为它们的编码 也在你后面匹配的范围里
直接把代码给我吧,真的急用呢,先谢谢拉

<script>
function test(key) {
if((event.keyCode!=37)&&(event.keyCode!=38)&&(event.keyCode!=39)&&(event.keyCode!=40)){
  
     document.getElementById('uaddress').value=key.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')
    }

}
<input name="uaddress" 
 id="uaddress"
 class="easyui-validatebox"
 style="width:180px"
required="true" 
missingMessage="必填" 
validType="length[1,200]"
onkeyup="test(this.value)">
</script>
[/quote] 上面的 标签位置错了
<script>
function test(key) {
if((event.keyCode!=37)&&(event.keyCode!=38)&&(event.keyCode!=39)&&(event.keyCode!=40)){
   
     document.getElementById('uaddress').value=key.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')
    }
 
}
</script>


<input name="uaddress" 
 id="uaddress"
 class="easyui-validatebox"
 style="width:180px"
required="true" 
missingMessage="必填" 
validType="length[1,200]"
onkeyup="test(this.value)">
jiangbai333 2014-04-03
  • 打赏
  • 举报
回复
引用 4 楼 lesbian0826 的回复:
引用 2 楼 jiangbai333 的回复:
你找一下左右键的编码 可能因为它们的编码 也在你后面匹配的范围里
直接把代码给我吧,真的急用呢,先谢谢拉

<script>
function test(key) {
if((event.keyCode!=37)&&(event.keyCode!=38)&&(event.keyCode!=39)&&(event.keyCode!=40)){
  
     document.getElementById('uaddress').value=key.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')
    }

}
<input name="uaddress" 
 id="uaddress"
 class="easyui-validatebox"
 style="width:180px"
required="true" 
missingMessage="必填" 
validType="length[1,200]"
onkeyup="test(this.value)">
</script>
scscms太阳光 2014-04-03
  • 打赏
  • 举报
回复
onkeyup意思是每次敲键盘后都执行。而你又用this.value=this.value.replace()不断赋值,在IE下就造成光标一直在后面(firefox等不会),所以建议你改成离开焦点再执行。 <input name="uaddress" id="uaddress" class="easyui-validatebox" style="width:180px" required="true" missingMessage="必填" validType="length[1,200]" onblur="this.value=this.value.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')">
jiangbai333 2014-04-03
  • 打赏
  • 举报
回复
引用 4 楼 lesbian0826 的回复:
引用 2 楼 jiangbai333 的回复:
你找一下左右键的编码 可能因为它们的编码 也在你后面匹配的范围里
直接把代码给我吧,真的急用呢,先谢谢拉
是这样的 我说错了刚刚 之所以在最后面 是因为 每次你按左右键的时候 都会执行匹配 匹配完之后 将input的value值改写 所以 你的光标不是没移动 是移动了 但是瞬间 又因为input重写 回到了最后面!
  • 打赏
  • 举报
回复
引用 2 楼 jiangbai333 的回复:
你找一下左右键的编码 可能因为它们的编码 也在你后面匹配的范围里
直接把代码给我吧,真的急用呢,先谢谢拉
  • 打赏
  • 举报
回复
引用 1 楼 aspwebchh 的回复:
onkeyup="this.value=this.value.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')"> 这个样子
试了一下没用噢,哥哥你快点帮帮我吖
jiangbai333 2014-04-03
  • 打赏
  • 举报
回复
你找一下左右键的编码 可能因为它们的编码 也在你后面匹配的范围里
挨踢直男 2014-04-03
  • 打赏
  • 举报
回复
onkeyup="this.value=this.value.replace(/[^\u4e00-\u9fa5a-zA-Z0-9-_.\/\\:]/g,'')"> 这个样子

87,997

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧