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)的更多相关文章

  1. 如何读取Linux键值,输入子系统,key,dev/input/event,dev/event,C语言键盘【转】

    转自:https://blog.csdn.net/lanmanck/article/details/8423669 相信各位使用嵌入式的都希望直接读取键值,特别是芯片厂家已经提供input驱动的情况下 ...

  2. 理解JavaScript中的事件处理 阻止冒泡event.stopPropagation();

    原文地址:http://www.cnblogs.com/binyong/articles/1750263.html 这篇文章对于了解Javascript的事件处理机制非常好,将它全文转载于此,以备不时 ...

  3. JavaScript Event Delegation, and event.target vs. event.currentTarget

    原文:https://medium.com/@florenceliang/javascript-event-delegation-and-event-target-vs-event-currentta ...

  4. Javascript中event.srcElement和event.target的区别

    event.srcElement 可以捕获当前事件作用的对象,如event.srcElement.tagName可以捕获活动标记名称.注意获取的标记都以大写表示,如"TD",&qu ...

  5. javascript中event.clientX和event.clientY用法的注意事项

    今天做项目用到了event.clientX和event.clientY,给元素定位,用定位的时候,让top和left等于事件元素的的坐标 <!DOCTYPE html> <html& ...

  6. C# 如何添加自定义键盘处理事件 如何配置app.config ? | csharp key press event tutorial and app.config

    本文首发于个人博客https://kezunlin.me/post/9f24ebb5/,欢迎阅读最新内容! csharp key press event tutorial and app.config ...

  7. JavaScript初探系列(十)——Event

    一.绑定事件的两种方式 (一).方式一:onclick 举例: <body> <button>点我</button> <script> var btn ...

  8. javascript 自定义事件 发布-订阅 模式 Event

    * javascript自定义事件 var myEvent = document.createEvent("Event"); myEvent.initEvent("myE ...

  9. javascript坐标:event.x、event.clientX、event.offsetX、event.screenX 用法

    clientX 设置或获取鼠标指针位置相对于窗口客户区域的 x 坐标,其中客户区域不包括窗口自身的控件和滚动条. clientY 设置或获取鼠标指针位置相对于窗口客户区域的 y 坐标,其中客户区域不包 ...

随机推荐

  1. Lua Doc生成工具

    Luadoc http://keplerproject.github.io/luadoc/ Overview LuaDoc is a documentation generator tool for ...

  2. 【python小练】图片爬虫之BeautifulSoup4

    Python3用不了Scrapy! Python3用不了Scrapy! Python3用不了Scrapy! [重要的事情说三遍,据说大神们还在尝试把scrapy移植到python3,特么浪费我半个小时 ...

  3. 【noip 2012】提高组Day2T3.疫情控制

    Description H国有n个城市,这n个城市用n-1条双向道路相互连通构成一棵树,1号城市是首都,也是树中的根节点. H国的首都爆发了一种危害性极高的传染病.当局为了控制疫情,不让疫情扩散到边境 ...

  4. mysql 约束和外键约束实例

    1.约束保证数据的完整性和一致性. 2.约束分为表级约束和列级约束.(根据约束所针对的字段的数目的多少来决定) 列级约束:对一个数据列建立的约束 表级约束:对多个数据列建立的约束 列级约束即可以在列定 ...

  5. tensorflow--logistic regression

    import tensorflow as tf from tensorflow.examples.tutorials.mnist import input_data mnist=input_data. ...

  6. [C++]PAT乙级1001.害死人不偿命的(3n+1)猜想(15/15)

    /* 1001.害死人不偿命的(3n+1)猜想 (15) 卡拉兹(Callatz)猜想: 对任何一个自然数n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把(3n+1)砍掉一半.这样一直反复砍下 ...

  7. 第25月第11天 deeplearning.ai

    1.网易云课堂 深度学习工程师 点击进入课程地址(英文)(收费) 点击进入课程地址(中文)(免费) 第一门 神经网络和深度学习 第二门 改善神经网络 第三门 结构化机器学习项目 第四门 卷积神经网络 ...

  8. 堆(heap)与栈(stack)

    编程语言书籍中经常解释: 值类型被创建在栈上,引用类型被创建在堆上.   构造函数,原型之类的算是引用类型吗? 5种基本数据类型有Undefined.Null.Boolean.Number 和 Str ...

  9. MongoDB 学习手册 - CURD

    mongoDB 增加数据 // mongoDB 增加数据: //新增数据insert( 字典 ) 表示插入一条数据,insert([字典]) 表示插入多条数据 // db.text01.insert( ...

  10. python - beautifulsoup4模块

    # beautifulsoup4学习 # 是一个python模块 用于接受一个HTML 或 XML 字符串,然后将其进行格式化,之后便可以使用模块提供的方法进行快速查找指定元素, # 从而是的在HTM ...