精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

增強型的 <input type=number>

開發 前端
我們可以使用min和max屬性設置界限,并且可以通過向上和向下鍵來添加或減少1,如果設置step屬性,則向上或向下鍵來添加或減少對應的 step 值。但是,如果我們想讓用戶以不同的step上下移動,該怎么辦?

本文轉載自微信公眾號「大遷世界」,轉載本文請聯系大遷世界公眾號。

input 標簽的 number 類型提供了一種處理數字的好方法。我們可以使用min和max屬性設置界限,并且可以通過向上和向下鍵來添加或減少1,如果設置step屬性,則向上或向下鍵來添加或減少對應的 step 值。但是,如果我們想讓用戶以不同的step上下移動,該怎么辦?

step不僅決定要添加或刪除的數量,還決定了該數字的限制位置。如果輸入的值為5,step 為10,然后按向上鍵,不會得到15(5 + 10),而是10(最接近的 step倍數)。

那么,我們希望用戶可以輸入任何數字又想增加10,要怎么做?

如何增強 input type=number 體驗

先來定義一些按鍵操作。當用戶在 input 標簽中使用方向鍵時,有一些對應的快捷操作:

  • 如果按的是向上或向下鍵盤,我們要對應的加減 1
  • 如果按的是shift并按向上或向下鍵,我們要對應的加減 10
  • 如果按的是alt并按向上或向下鍵,我們要對應的加減 0.1
  • 如果按的是ctrl并按向上或向下鍵,我們要對應的加減 100, Mac 對應的 cmd 鍵
  • 如果輸入內容為空,則根據 min 值來計算

實現

這是完整的代碼,它相對簡潔,僅約20行代碼。

  1. const isMac = navigator.platform === 'MacIntel'; 
  2.  
  3. const KEY = { 
  4.   UP: 38, 
  5.   DOWN: 40, 
  6. }; 
  7.  
  8. document.querySelector("input").addEventListener("keydown", e => { 
  9.   if ([KEY.UP, KEY.DOWN].includes(e.keyCode)) { 
  10.     e.preventDefault(); 
  11.      
  12.     const currentValue = isNaN(parseFloat(e.target.value)) 
  13.       ? parseFloat(e.target.getAttribute("min")) || 0 
  14.       : parseFloat(e.target.value); 
  15.        
  16.     const direction = e.keyCode === KEY.UP ? 1 : -1; 
  17.      
  18.     const modifier = (isMac ? e.metaKey : e.ctrlKey) ? 100 : e.shiftKey ? 10 : e.altKey ? 0.1 : 1; 
  19.      
  20.     const decimals = Math.max( 
  21.       (currentValue.toString().split(".")[1] || "").length, 
  22.       e.altKey ? 1 : 0 
  23.     ); 
  24.      
  25.     const newValue = currentValue + direction * modifier; 
  26.      
  27.     e.target.value = newValue.toFixed(decimals); 
  28.   } 
  29. }); 

這段代碼有些部分可能不是很好看懂,我們來逐行看看,表示的含義。

  1. const isMac = navigator.platform === 'MacIntel'; 
  2.  
  3. const KEY = { 
  4.   UP: 38, 
  5.   DOWN: 40, 
  6. }; 

在 Windows 和 Linux 中,ctrl是我們想要使用的鍵,但在 Mac 上更常用的是cmd。isMac是一個布爾值,表示是 Mac 還是 Window 系統。

你在鍵盤上按下的每個鍵都有一個唯一的鍵碼。向上箭頭鍵是38向下箭頭鍵是40。因為我不喜歡代碼中的魔法數字,所以我們將它們存儲在一個對象中以便以后使用。

  1. document.querySelector('input').addEventListener('keydown', e => { 
  2.   ... 

然后是監聽 input 的 keydown 事件。keydown 可以告訴我們按下哪個鍵以及按下哪個修飾鍵的事件。我們感興趣的修飾鍵是shift,alt,ctrl和cmd。metaKey 對應是 Mac 上是cmd鍵,在Windows中是 windows 鍵。

  1. if ([KEY.UP, KEY.DOWN].includes(e.keyCode)) { 
  2.   e.preventDefault(); 
  3.   ... 

如果用戶是向左或向右鍵,我們將不執行任何操作。我們在代碼周圍添加了一個if子句,以便僅在用戶按向上或向下鍵盤才執行。當用戶按向上或向下鍵時,我們調用e.preventDefault()。這樣可以防止輸入內容被更新,因為我們會自己做。

  1. const currentValue = isNaN(parseFloat(e.target.value)) 
  2.   ? parseFloat(e.target.getAttribute("min")) || 0 
  3.   : parseFloat(e.target.value); 

你可能會認為獲取值與獲取e.target.value一樣容易,但是,我們必須做更多的工作。e.target.value始終是一個字符串,即使對于npmber類型的 input 元素也是如此,因此,要進行任何數學運算,我們都需要將其轉換為數字。因為我們需要能夠加/減0.1,所以我們需要使用浮點數而不是整數。

是,如果輸入為空,我們調用parseFloat,它返回的是一個NaN值。由于我們無法添加或減去NaN,因此我們需要對些時行判斷。如果輸入為空,那么我們將獲得最小值(如果存在),或者默認為0。最小值也是一個字符串,因此我們也需要對其進行轉換。

如果min屬性未定義,它就變成NaN,而NaN || 0解析為0,所以得到結果是可以計算的。

  1. const direction = e.keyCode === KEY.UP ? 1 : -1; 

從if子句中我們已經知道用戶按下的向上或向下的鍵,所以需要檢查用戶是按向上還是向下鍵盤,以便確定是否需要加或減。我們用變量 “direction” 來保存,如果是向上,值為1,向下則為 -1,之后可以將其與以后的值相乘。

  1. const modifier = (isMac ? e.metaKey : e.ctrlKey) ?  
  2.   100 :  
  3.   e.shiftKey ?  
  4.     10 :  
  5.     e.altKey ?  
  6.       0.1 :  
  7.       1; 

我們找出按下了哪個修飾鍵。事件屬性可以告訴我們。如果在我們按下的是向上或向下鍵的同時還按下 shift 或 alt 鍵,則e.shiftKey,e.altKey的值為 true。

我們首先使用(isMac ? e.metaKey : e.ctrlKey)來檢查meta鍵或 ctrl鍵,具體取決于我們是否在 Mac上。如果是這樣,我們將相加或相減 100。如果改為按Shift鍵,則我們用10加或減,如果按Alt鍵,則加0.1。如果沒有按下這些鍵,則按“默認”行為加1或減1。

  1. const decimals = Math.max( (currentValue.toString().split(".")1 || "").length, e.altKey ? 1 : 0 ); 

這里有點棘手,因為我們使用的是浮動。由于四舍五入的關系,JavaScript 中的浮點數可能會產生意想不到的結果。具體來說,如果你加上例如0.1``和0.2,你得到的值是0.30000000000000004,大約是0.3。

在進行基本計算時,0 的數量太多,但并不重要,在 input 元素中,0.30000000000000004看起來不是很好。我們只要 0.3。為了達到這個目的,我們需要知道在計算前的小數的最大數量是多少,就是當前輸入的小數的數量,或者是按下alt鍵時的1,兩者中哪個更大。我們存儲這個值以便以后使用。

  1. const newValue = currentValue + direction * modifier; 

這是最終的結果值。我們知道當前值,要增加或減少的數量以及是否需要增加或減少。

我們將modifier(要添加的數量)與direction(即+1或-1)相乘,以便在將其添加到當前值時可以相加或相減。

現在我們已經計算了新值,但是由于前面提到的可能很奇怪的四舍五入,我們不能直接將它設置為新值作為輸入值,因為它可能有很多小數。相反,我們使用toFixed與我們之前找到的小數的數目

  1. e.target.value = newValue.toFixed(decimals); 

這,就是所有的代碼。

這個input可以讓用戶快速增加或減少數值,或者精確地鎖定一個數字,這取決于用戶按的是哪個修改鍵。

原文:https://kilianvalkhof.com/2020/javascript/supercharging-input-type-number/

 

責任編輯:趙寧寧 來源: 大遷世界
相關推薦

2012-12-06 10:34:36

戴爾

2015-12-02 16:13:34

GPUUCloud云主機

2014-07-04 09:58:25

傳輸系統地鐵華為

2015-03-05 14:58:42

服務器交換機虛擬化

2018-02-27 11:09:22

地鐵

2014-01-03 09:15:57

2015-11-03 11:48:12

SanDisk閃迪VMware

2009-04-10 08:59:59

2017-02-13 14:01:11

華為

2020-10-27 14:53:29

AndroidChrome增強保護

2009-02-19 10:18:32

FCoE增強型以太網以太網光纖

2020-09-30 10:56:13

Facebook 開發開源

2019-04-17 16:48:32

青云QingCloudCPU

2014-03-12 17:04:36

eLTE寬帶集群華為

2021-08-11 17:02:00

Firefox 火狐瀏覽器

2021-02-05 17:41:21

大數據增強型分析數據虛擬化

2021-10-18 16:45:41

臺積電芯片存儲

2024-07-04 09:00:00

2016-01-12 15:16:44

城市軌道交通華為

2014-11-03 09:39:31

華為鐵路
點贊
收藏

51CTO技術棧公眾號

欧美在线精品免播放器视频| 欧美喷潮久久久xxxxx| 国产精品一区二区三区免费| 欧美日韩中文视频| 国产精选一区| 91精品国产91热久久久做人人| 男人添女人下部视频免费| 外国精品视频在线观看 | 欧美久久久精品| 国产精久久久久| 校园春色亚洲色图| 亚洲欧美另类在线| 美女精品国产| 国产视频在线免费观看| 亚洲永久视频| 久久福利视频导航| 成人免费看aa片| 精品午夜视频| 日本精品一区二区三区高清| 亚洲区成人777777精品| 青梅竹马是消防员在线| 精品在线观看视频| 欧美在线视频播放| 18岁成人毛片| 欧美日韩激情| 亚洲精品91美女久久久久久久| 欧美伦理视频在线观看| 性欧美videos高清hd4k| 2023国产一二三区日本精品2022| 国产剧情久久久久久| 波多野结衣亚洲色图| 成人三级视频| 亚洲另类欧美自拍| 蜜臀aⅴ国产精品久久久国产老师| 国产极品一区| 色哟哟日韩精品| 免费 成 人 黄 色| 呦呦在线视频| 亚洲欧美国产毛片在线| 亚洲国产精品一区二区第一页| 欧美高清电影在线| www.在线成人| 国产精品二区二区三区| 国产又粗又猛又爽| 美女看a上一区| 欧美中文字幕第一页| 国产一级片播放| 欧美激情五月| 久久福利视频导航| 欧美在线视频第一页| 日本大胆欧美| 日韩中文在线不卡| 国精产品久拍自产在线网站| 精品免费av| 一区二区三区日韩在线| 黄色三级生活片| 欧美男男gaytwinkfreevideos| 亚洲精品成人免费| jjzz黄色片| 久久超级碰碰| 精品久久久久久久一区二区蜜臀| 国产欧美一区二| 视频一区在线免费看| 欧美性黄网官网| 青青青青草视频| 午夜伦理大片视频在线观看| 亚洲欧洲无码一区二区三区| 亚洲精品日韩精品| 亚洲aaaaaaa| 97久久精品人人做人人爽50路| 国产欧美丝袜| 天堂中文网在线| jlzzjlzz亚洲日本少妇| 电影午夜精品一区二区三区| av在线资源观看| 国产揄拍国内精品对白| 91精品在线观| aaa一区二区| 国产成人免费视频网站| 91欧美视频网站| 国产视频一区二区三| 精品一区二区三区视频 | 日本一区二区三区www| 国产九色在线| 中文字幕一区二区在线播放| 一区二区三区欧美在线| 巨大荫蒂视频欧美大片| 日韩美女精品在线| 国产欧美综合一区| 日韩免费影院| 香蕉加勒比综合久久| 无码人妻丰满熟妇区96| 黄页网站大全在线免费观看| 国产精品久久99| 18视频在线观看娇喘| 伊人春色在线观看| 午夜激情一区二区三区| 日韩手机在线观看视频| 99精品国自产在线| 日韩欧美一区在线观看| 呦呦视频在线观看| 不卡视频在线| 欧美另类高清videos| 999这里只有精品| 免费成人av资源网| 97神马电影| 青春草在线观看| 亚洲欧洲国产专区| 男人插女人视频在线观看| 久久青青视频| 91精品国产91综合久久蜜臀| 亚洲男人在线天堂| 成人在线免费观看视频| 欧美激情综合色综合啪啪五月| 国产性xxxx高清| 久久99精品久久久久久国产越南 | 日韩中文在线字幕| 鲁鲁在线中文| 欧美精品丝袜中出| 三级男人添奶爽爽爽视频| 成人情趣视频网站| 91精品成人久久| 91麻豆视频在线观看| 9i在线看片成人免费| 亚洲丰满在线| 成人免费图片免费观看| 欧美在线播放高清精品| 91人妻一区二区| 欧美国产美女| 欧美一级黑人aaaaaaa做受| ,一级淫片a看免费| 久久综合九色综合97_久久久| 中文字幕一区二区三区乱码| 69久成人做爰电影| 欧美videossexotv100| 国产传媒国产传媒| 国产欧美日韩一级| 国产精品三区在线| 黄色在线视频网站| 欧美三级韩国三级日本一级| 一级黄色片毛片| 外国成人免费视频| 国产成人精品亚洲精品| 亚洲精品一区二区三区不卡| 国产精品天干天干在线综合| 欧美在线观看www| 都市激情久久| 欧美大奶子在线| 国产剧情久久久| 日本一二三四高清不卡| 37pao成人国产永久免费视频| 成人另类视频| 久久全国免费视频| 欧美一级在线免费观看| 国产精品电影院| 欧美 国产 日本| 日韩精品免费一区二区夜夜嗨 | 欧美精品videossex少妇| 欧美日韩一二区| 精品国产成人亚洲午夜福利| 亚洲一区欧美激情| 精品欧美一区二区精品久久| 24小时免费看片在线观看| 精品福利一二区| 久久激情免费视频| 国产精品夜夜嗨| 色哟哟免费网站| 日本一区二区三区视频在线看 | 国产精品成人免费一区久久羞羞| 影音先锋日韩在线| 91亚洲永久免费精品| 国内精品久久久久久野外| 欧美精品日韩一区| 日本裸体美女视频| 精品一区二区久久久| 一区二区成人国产精品| 91精品亚洲一区在线观看| 久久综合久久八八| 精品二区在线观看| 一区二区三区在线高清| 337p日本欧洲亚洲大胆张筱雨| 欧美成人tv| 国产91视觉| gogo高清在线播放免费| 亚洲成人久久网| 六月丁香在线视频| 99在线精品免费| 欧美精品成人网| 久久精品高清| 91亚洲精品久久久| 成人免费高清观看| 亚洲精品自拍偷拍| 中文在线最新版天堂| 亚洲丝袜美腿综合| 日本精品一二三区| 性欧美精品高清| 桥本有菜av在线| 成人激情自拍| 国产精品国产亚洲伊人久久| 国产三区在线观看| 日韩av一区二区在线观看| 五月婷婷视频在线| 国产精品久99| 星空大象在线观看免费播放| 久久激情视频| 国产日韩第一页| 国产日韩三级| 国产精品久久久久9999| 日本电影在线观看| 亚洲人成啪啪网站| 国产成人a人亚洲精品无码| 舔着乳尖日韩一区| 中国1级黄色片| 99r国产精品| 肉色超薄丝袜脚交| 国产精品久久久免费| 杨幂一区欧美专区| 国产精品主播在线观看| 国产精品极品美女在线观看免费| 亚洲综合影视| 中文字幕日韩视频| 国产成人精品免费看视频| 在线视频国产一区| 日本免费一二三区| 亚洲欧洲日产国产综合网| xxxwww国产| 黄网站免费久久| 欧美黄网站在线观看| 欧美aa国产视频| 亚洲春色在线| 国产一卡不卡| 国产精品swag| 高清一区二区三区av| 国产va免费精品高清在线| 肉肉视频在线观看| 精品国产自在精品国产浪潮| 少妇人妻偷人精品一区二区| 日韩精品专区在线影院观看| 97久久人国产精品婷婷| 91豆麻精品91久久久久久| 激情综合网五月天| 国产精品久久久久久久第一福利| 色天使在线视频| 国产v日产∨综合v精品视频| 日本肉体xxxx裸体xxx免费| 久久aⅴ国产紧身牛仔裤| 91黄色在线看| 欧美激情aⅴ一区二区三区| 亚洲一区二区三区欧美| 欧美男同视频网| 久久久久久久久四区三区| 亚洲精品一区国产| 国产精品久久久久秋霞鲁丝| 精品免费av一区二区三区| 2019av中文字幕| 岛国av在线播放| 97精品欧美一区二区三区| 中文字幕伦理免费在线视频 | 日韩欧美在线免费观看| 少妇一级淫片免费放中国| 亚洲一二三区视频在线观看| 岛国毛片在线观看| 樱桃视频在线观看一区| 欧美亚洲日本在线| 一区二区三区在线看| 欧美国产日韩在线观看成人| 亚洲天天做日日做天天谢日日欢 | 国产精品传媒在线| 中国特黄一级片| 中文字幕一区二区视频| 国产黄色小视频网站| 亚洲天天做日日做天天谢日日欢| 1024在线看片| 国产精品精品国产色婷婷| 日本女人性生活视频| 国产精品天美传媒沈樵| 人人澡人人澡人人看| 亚洲欧美成aⅴ人在线观看| 欧美国产日韩综合| 亚洲乱码日产精品bd| www日韩精品| 色婷婷av一区| 中文字幕一区二区免费| 制服丝袜亚洲网站| 成人黄色免费视频| 日韩精品中文字幕久久臀| 日韩一区av| 日韩有码在线电影| 欧美韩日亚洲| 欧美有码在线视频| 69堂免费精品视频在线播放| 国产日韩中文在线| 国产在线不卡一区二区三区| 精品伦理一区二区三区| 欧美日韩国产一区二区三区不卡 | 一本色道久久综合亚洲精品酒店| 色姑娘综合网| 日韩欧美字幕| 99精品人妻少妇一区二区 | 久久精品国产精品| xxxcom在线观看| 国产成人黄色av| 香蕉久久一区| 不卡视频一区二区| 国产影视一区| 黄色污污在线观看| 亚洲国产美女| 亚洲图片 自拍偷拍| 波多野洁衣一区| 亚洲精品国产精品乱码在线观看| 午夜久久久影院| 亚洲一级特黄毛片| 亚洲加勒比久久88色综合 | www.日韩欧美| 欧美日韩国产观看视频| 国产精品爽黄69天堂a| 风间由美一区二区av101| 日日噜噜噜噜夜夜爽亚洲精品| 欧美精品一线| 色婷婷综合久久久久中文字幕 | 黄色片视频在线免费观看| 久久se这里有精品| 亚洲观看黄色网| 亚洲六月丁香色婷婷综合久久| 国产无人区码熟妇毛片多| 日韩欧美美女一区二区三区| 黄色在线网站| 欧美激情视频在线观看| 456成人影院在线观看| 成人午夜电影在线播放| 日韩精品久久久久久久电影99爱| 国产 日韩 欧美在线| 麻豆久久久久久| 精品人妻中文无码av在线| 亚洲大片一区二区三区| 国产女18毛片多18精品| 国产亚洲欧洲高清一区| gogo高清午夜人体在线| 99se婷婷在线视频观看| gogogo高清在线观看一区二区| 大j8黑人w巨大888a片| 国产精品18久久久久久vr| 黄色片网站在线播放| 日本丶国产丶欧美色综合| 人成网站在线观看| 欧美成人全部免费| 蜜桃精品在线| 香蕉久久夜色| 日韩av在线免费观看不卡| 99久久久久久久久久| 精品电影在线观看| 亚洲AV无码一区二区三区少妇| 国产亚洲精品久久久久久牛牛| 你懂得影院夜精品a| 免费日韩av电影| 国产农村妇女精品一区二区| 中文字幕第3页| 亚洲国产一区二区视频| 朝桐光av在线一区二区三区| 久久久久久尹人网香蕉| 国产一区二区三区国产精品| 亚洲国产精品影视| 久久国产精品免费| 成年人视频软件| 欧美日韩夫妻久久| 成人a在线视频免费观看| 成人午夜小视频| 亚洲乱码在线| 午夜视频在线免费看| 亚洲综合一二三区| 99热精品在线播放| 欧美精品久久久久久久| 精品国内亚洲2022精品成人| 性欧美大战久久久久久久| av在线不卡电影| 日日噜噜噜噜人人爽亚洲精品| 日韩av一区二区在线| 成人精品高清在线视频| 欧美 另类 交| 国产不卡视频在线观看| 国产精品100| 中文字幕日韩精品在线观看| 国产麻豆一区二区三区| 国产一级做a爰片久久毛片男| av一二三不卡影片| 亚洲婷婷综合网| 日韩在线观看免费网站 | 欧美另类综合| 爱爱的免费视频| 欧美日韩免费视频| 羞羞视频在线观看不卡| 精品亚洲一区二区三区四区五区高| 久久久久看片| 18岁成人毛片| 精品亚洲一区二区三区| 岛国一区二区| 真实国产乱子伦对白视频| 99riav久久精品riav| 中文字幕日韩经典| 欧美激情亚洲一区|