微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

用Javascript检测大小写键是否开着

刚看了一段老外的代码,发觉不起作用,我用的 MS IE6,可是我大写键并未打开,按字母也提示

<scrīpt>
function capLock(e){
kc = e.keyCode?e.keyCode:e.which;
sk = e.shiftKey?e.shiftKey:((kc == 16)?true:false);
if(((kc >= 65 && kc <= 90) && !sk)||((kc >= 97 && kc <= 122) && sk))
document.getElementById('divMayus').style.visibility = 'visible';
else
document.getElementById('divMayus').style.visibility = 'hidden';
}
</scrīpt>

<input type=password name=txtPassword ōnkeypress=capLock(event) />
<div id=divMayus style=visibility:hidden>Caps Lock is on.</div>

后来我突然想到 toLowerCase() 这个方法,如果大小写键开着,键入的值和该值的小写一定不同,这样子对比,不就知道了大写键是否打开了吗?

<scrīpt>
function capLock(){
kc = event.srcElement.value;
if(kc!=kc.toLowerCase())
document.getElementById('divMayus').style.visibility = 'visible';
else
document.getElementById('divMayus').style.visibility = 'hidden';
}
</scrīpt>
<input type=test name=txtPassword ōnkeyup=capLock() />
<div id=divMayus style=visibility:hidden>Caps Lock is on.</div>

写完了发现两个问题,1)是大写键开着,但是如果只输入数字,仍然不会给提示。所幸的是,数字没大小写之分; 2)只要输入了一个大写字母,以后即使大写键关了,也仍然给提示,那我想就只有设置一个变量来保存之前输入的了,可是这样似乎麻烦了许多

一个办法是,就检测最后输入的那个字符,具体代码还没写,回头再说吧 。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐