小码哥的IT人生

KeyboardEvent charCode 属性

JavaScript基础 2022-06-08 12:04:19小码哥的IT人生shichen

KeyboardEvent charCode 属性

实例

获取按下的键盘键的 Unicode 值:

var x = event.charCode;

完整实例:

<!DOCTYPE html>
<html>
<body>
<p>在输入字段中按键盘上的某个键可获取被按下键的 Unicode 字符代码。</p>
<input type="text" size="40" onkeypress="myFunction(event)">
<p id="demo"></p>
<p><b>注释:</b>IE8 及更早版本不支持 charCode 属性。</p>
<script>
function myFunction(event) {
  var x = event.charCode;
  document.getElementById("demo").innerHTML = "The Unicode value is: " + x;
}
</script>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

页面下方有更多 TIY 实例。

定义和用法

charCode 属性返回触发 onkeypress 事件 的键的 Unicode 字符代码。

Unicode 字符代码是一种字符的编号(例如数字 "97" 代表字母 "a")。

提示:有关所有 Unicode 字符的列表,请参阅我们的 完整 Unicode 参考

提示:如果要将 Unicode 值转换为字符,请使用 fromCharCode() 方法

注释:如果该属性用于 onkeydownonkeyup 事件,则返回值始终为 "0"。

注释:该属性只读。

注释:IE8 及更早版本不支持 charCode 属性。但是,对于这些浏览器版本,您可以使用 keyCode 属性。或者,针对跨浏览器解决方案,您可以使用如下代码:

var x = event.charCode || event.keyCode; // 使用 charCode 还是 keyCode,取决于浏览器支持

提示:您还可以使用 keyCode 属性来检测特殊键(例如大写锁定或方向键)。但是,同时提供 keyCode 和 charCode 属性只是为了兼容性。最新版本的 DOM 事件规范建议改用 key 属性(如果可用)。

提示:如果您想知道在发生按键事件时是否按下了 "ALT"、"CTRL"、"META" 或 "SHIFT" 键,请使用 altKeyctrlKey/、metaKeyshiftKey 属性。

浏览器支持

表中的数字注明了完全支持该属性的首个浏览器版本。

属性 Chrome IE Firefox Safari Opera
charCode 支持 9.0 支持 支持 支持

语法

event.charCode

技术细节

返回值: 数字值,表示 Unicode 字符代码。
DOM 版本: DOM Level 2 Events

更多实例

示例代码:

获取所按键盘键的 Unicode 值的跨浏览器解决方案:

// 如果浏览器支持,则使用 charCode,否则使用 keyCode(适用于 IE8 及更早版本)
var x = event.charCode || event.keyCode;

完整实例:

<!DOCTYPE html>
<html>
<body>
<p>在输入字段中按键盘上的某个键可获取被按下键的 Unicode 字符代码。</p>
<input type="text" size="40" onkeypress="myFunction(event)">
<p id="demo"></p>
<script>
function myFunction(event) {
  // 如果浏览器支持,请使用 charCode,否则请使用 event.keyCode(适用于 IE8 及更早版本)
  var x = event.charCode || event.keyCode;
  document.getElementById("demo").innerHTML = "The Unicode value is: " + x;
}
</script>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

示例代码:

如果用户按下 "O" 键,则提示一些文本:

function myFunction(event) {
  var x = event.charCode || event.keyCode;
  if (x == 111 || x == 79) { // o 是 111,O 是 79
    alert("You pressed the 'O' key!");
  }
}

完整实例:

<!DOCTYPE html>
<html>
<body>
<p>在输入字段中按键盘上的 "O" 键来提示一些文本。</p>
<input type="text" size="40" onkeypress="myFunction(event)">
<p id="demo"></p>
<script>
function myFunction(event) {
  var x = event.charCode || event.keyCode;
  if (x == 111 || x == 79) {  // o is 111, O is 79
    alert("You pressed the 'O' key!");
  }
}
</script>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

示例代码:

将 Unicode 值转换为字符:

var x = event.charCode || evt.keyCode;   // 获取 Unicode 值
var y = String.fromCharCode(x);          // 把值转换为字符

完整实例:

<!DOCTYPE html>
<html>
<body>
<p>在输入字段中按键盘上的某个键可获取被按下键的数字和字符。</p>
<input type="text" size="40" onkeypress="myFunction(event)">
<p id="demo"></p>
<script>
function myFunction(event) {
  var x = event.charCode || event.keyCode;  // 获取 Unicode 值
  var y = String.fromCharCode(x);       // 将值转换为字符
  document.getElementById("demo").innerHTML = "Number: " + x + " = Character: " + y;
}
</script>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

版权所有 © 小码哥的IT人生
Copyright © phpcodeweb All Rights Reserved
ICP备案号:苏ICP备17019232号-2  

苏公网安备 32030202000762号

© 2021-2024