JavaScript 输入小数点(event.key或event.code)
1. 概述
1.1 说明
在开发过程中,有时候需要仅输入数字与小数,故记录下使用过的功能,以便后期使用。
1.2 key
定义:按下按键时返回的标识符,按键标识符是表示键盘按钮的字符串(如1,2,a等)。
使用:event.key去获取按下按键的字符串。
1.3 keyCode
定义:按下按键时此按键值所对应的字符代码(如ESC键为27)。
使用:event.keyCode去获取按下按键的字符码。
备注:此功能已废弃,但是仍然可以使用。
2. 示例
2.1 js代码
/**
* 输入为小数
* @param event 事件
* @param allowPoint 是否包含小数点
**/
function inputNumber (event, allowPoint) {
let bInputTrue = false;
if (event.key !== undefined) {
let arrNumber = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, "Backspace", "Delete","Shift"];//数字键盘与删除键
let arrTopNumber = ["Digit0", "Digit1", "Digit2", "Digit3", "Digit4", "Digit5", "Digit6", "Digit7", "Digit8", "Digit9"];//中文_上边数字键盘
let arrNumNumber = ["Numpad1", "Numpad2", "Numpad3", "Numpad4", "Numpad5", "Numpad6", "Numpad7", "Numpad8", "Numpad9"];//中文_右边数字键盘
if (allowPoint) {
arrNumber.push(".");
arrTopNumber.push("Period");
arrTopNumber.push("NumpadDecimal");
}
if(event.key=="Process"){
for (let i = 0; i < arrTopNumber.length; i++) {
if (event.code == arrTopNumber[i]) {
bInputTrue = true;
break;
}
}
if(bInputTrue ==false ){
for (let i = 0; i < arrNumNumber.length; i++) {
if (event.code == arrNumNumber[i]) {
bInputTrue = true;
break;
}
}
}
} else {
for (let i = 0; i < arrNumber.length; i++) {
if (event.key == arrNumber[i]) {
bInputTrue = true;
break;
}
}
} } else if (event.keyCode !== undefined) {
let charCode = event.keyCode;
let bCondition1 = charCode >= 48 && charCode <= 57; //数字
let bCondition2 = charCode >= 96 && charCode <= 105; //小键盘数字
let bCondition3 = charCode == 46 || charCode == 8; //两个删除键 let decimalPoint = charCode == 110 || charCode == 190;//小数点
let bCondition = null;
let bShift = event.shiftKey == 1; if (allowPoint) {
bCondition = bCondition1 || bCondition2 || bCondition3 || decimalPoint;
} else {
bCondition = bCondition1 || bCondition2 || bCondition3;
}
if (bCondition && !bShift) {
bInputTrue = true;
} else {
bInputTrue = false;
}
}
if (bInputTrue) {
return true;
} else {
document.activeElement.blur();//使失去焦点
if (event.preventDefault) {
event.preventDefault();//中文情况下不起作用
}
else {
event.returnValue = false;
}
}
}
注意:代码 document.activeElement.blur(); 会使输入框焦点失去,故此处可考虑是否使用。
2.1 html代码
<input onkeydown="inputNumber(event,true)" onpaste="return false" ondragenter="return false" oncontextmenu="return false;" style="ime-mode:disabled">
JavaScript 输入小数点(event.key或event.code)的更多相关文章
- 如何读取Linux键值,输入子系统,key,dev/input/event,dev/event,C语言键盘【转】
转自:https://blog.csdn.net/lanmanck/article/details/8423669 相信各位使用嵌入式的都希望直接读取键值,特别是芯片厂家已经提供input驱动的情况下 ...
- 理解JavaScript中的事件处理 阻止冒泡event.stopPropagation();
原文地址:http://www.cnblogs.com/binyong/articles/1750263.html 这篇文章对于了解Javascript的事件处理机制非常好,将它全文转载于此,以备不时 ...
- JavaScript Event Delegation, and event.target vs. event.currentTarget
原文:https://medium.com/@florenceliang/javascript-event-delegation-and-event-target-vs-event-currentta ...
- Javascript中event.srcElement和event.target的区别
event.srcElement 可以捕获当前事件作用的对象,如event.srcElement.tagName可以捕获活动标记名称.注意获取的标记都以大写表示,如"TD",&qu ...
- javascript中event.clientX和event.clientY用法的注意事项
今天做项目用到了event.clientX和event.clientY,给元素定位,用定位的时候,让top和left等于事件元素的的坐标 <!DOCTYPE html> <html& ...
- C# 如何添加自定义键盘处理事件 如何配置app.config ? | csharp key press event tutorial and app.config
本文首发于个人博客https://kezunlin.me/post/9f24ebb5/,欢迎阅读最新内容! csharp key press event tutorial and app.config ...
- JavaScript初探系列(十)——Event
一.绑定事件的两种方式 (一).方式一:onclick 举例: <body> <button>点我</button> <script> var btn ...
- javascript 自定义事件 发布-订阅 模式 Event
* javascript自定义事件 var myEvent = document.createEvent("Event"); myEvent.initEvent("myE ...
- javascript坐标:event.x、event.clientX、event.offsetX、event.screenX 用法
clientX 设置或获取鼠标指针位置相对于窗口客户区域的 x 坐标,其中客户区域不包括窗口自身的控件和滚动条. clientY 设置或获取鼠标指针位置相对于窗口客户区域的 y 坐标,其中客户区域不包 ...
随机推荐
- json中带有\r\n处理
后台代码把换行符\r\n替换为\\r\\n,前台代码js收到的字符就是\r\n
- visual studio code运行时报错,无法将“cnpm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称,Cannot find module 'webpack'
前言 因公司技术需求,这段时间成功进入了Vue 2.0 的坑,刚用起Visual Studio Code,却发现问题很多,发现一个错误:cnpm : 无法将“cnpm”项识别为 cmdlet.函数.脚 ...
- Vue.js 技术揭秘(学习) 深入响应式原理 nextTick外传
microTask mutationObserve. promise.then macroTask setImmediate. messageChannnel.setTimeout.postMess ...
- 使用Excel过滤重复数据
如题 由于数据太多,没有办法人工过滤,所以借助Excel 我的数据是这样的 需要找出里面重复的数据 首先,选中需要筛选的数据,点击开始 --> 条件格式 --> 突出显示单元格规则 --& ...
- Centos 04 基础系统优化命令
在Linux这个系统当中,几乎所有的硬件设备文件都在/dev这个目录内.举例来说,IDE介面的硬盘的文件名称即为/dev/hd[a-d],其中, 括号内的字母为a-d当中的任意一个,亦即有/dev/h ...
- centos6.8安装python3.7无法import _ssl
转载https://www.jianshu.com/p/ace9be0b08ed 公司运维提供的服务器是centos6.8,打算在上面装python3.7,结果费尽周折,按照网上的步骤python3. ...
- RESTful支持
springmvc restful 支持 - 哎幽的成长 - CSDN博客http://blog.csdn.net/u012373815/article/details/47208345 RESTfu ...
- i春秋 小漏洞也有大梦想
i春秋上的课,提到了一些概念,学习并记录. 此文主要以了解概念为主,没有代码和实战. 水坑式攻击 百度定义: “水坑式攻击”,是指黑客通过分析被攻击者的网络活动规律,寻找被攻击者经常访问的网站的弱点, ...
- jquery判断表单内容是否为空
//判断表单数据是否为空 var t = $('form').serializeArray(); $.each(t,function(i,item){ if(item['value'] == '') ...
- T5557 读写卡详解
T5557的基本信息就不在这里详细介绍,不了解的可以去看T5557的收据手册. 一上来直接开始讲操作 存在七种操作,我们重点介绍四种,Standard Write,Protected Write,Di ...