精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

深夜成人福利| 国产又粗又猛又黄又爽| 日韩电影不卡一区| 亚洲精品中文字幕在线观看| 成人有码视频在线播放| 无码人妻精品一区二区三区夜夜嗨 | 美国十次了思思久久精品导航| 日韩一区二区福利| 第一页在线视频| 天堂电影一区| 国产精品视频你懂的| 亚洲a级在线观看| 在线观看 中文字幕| 精品高清在线| 日韩视频一区二区三区在线播放| 免费国产黄色网址| 91精彩视频在线观看| 国产在线麻豆精品观看| 欧美激情一区二区三级高清视频 | 亚洲欧美一级| 亚洲va国产天堂va久久en| 欧美在线一二三区| 精品乱子伦一区二区| 欧美亚洲在线| 欧美成人精品h版在线观看| 国产黄色三级网站| 国产精品扒开腿做爽爽爽视频软件| 国产精品电影一区二区| 亚洲自拍偷拍第一页| 波多野结衣 久久| 精品国产一区二区三区小蝌蚪 | 日韩欧美黄色大片| 日本孕妇大胆孕交无码| 亚洲国产精品av| 91亚洲永久免费精品| 探花视频在线观看| 99国产精品免费视频观看| 亚洲精品电影网| 欧美精品 - 色网| 日韩精品三区| 婷婷夜色潮精品综合在线| 伊人久久av导航| 免费人成在线观看网站| 国产成人精品一区二| 国产精品偷伦视频免费观看国产 | 国产欧美日韩专区发布| 国产在线观看黄色| 一区在线播放| 欧美成人四级hd版| 欧美自拍偷拍网| 成人性生交大片免费看96| 欧美日韩综合不卡| 韩国日本在线视频| а√天堂中文在线资源8| 亚洲色图制服诱惑| 亚洲一区美女| 一本一道波多野毛片中文在线| 91丝袜呻吟高潮美腿白嫩在线观看| 亚洲综合视频1区| 国产巨乳在线观看| 六月婷婷色综合| 国产精品久久久久久久久久久久久久| 亚洲天堂日韩av| 亚洲日本免费| 久久久久久久久久久网站| 朝桐光av在线| 牛牛国产精品| 超碰91人人草人人干| 四虎永久免费地址| 国产精品久久久乱弄| 久久精品国产2020观看福利| 蜜桃av.com| 成人综合专区| www.日韩欧美| 久久久久久久麻豆| 日韩av在线播放网址| 视频在线观看99| 午夜国产小视频| 欧美fxxxxxx另类| 九色91av视频| 国产无套内射又大又猛又粗又爽| 国语精品一区| 高清一区二区三区四区五区| 国产午夜久久久| 性伦欧美刺激片在线观看| 欧美一级免费视频| 中文字幕高清在线免费播放| 美日韩一级片在线观看| 91精品视频播放| 成人小说亚洲一区二区三区| 国产毛片一区二区| 国产欧美日韩在线播放| 四虎精品成人免费网站| 中文字幕亚洲一区二区av在线| 91动漫在线看| 日韩一区精品| 亚洲第一免费播放区| 一级黄色片网址| 欧美日韩日本国产亚洲在线| 欧洲亚洲妇女av| 国产熟女精品视频| 久久青草欧美一区二区三区| 裸体裸乳免费看| 成人片免费看| 精品裸体舞一区二区三区| 熟女俱乐部一区二区| 亚洲国产精品91| 国产成人啪精品视频免费网| av中文在线观看| 久久品道一品道久久精品| 毛片在线视频观看| 电影一区电影二区| 精品无码久久久久久国产| 人人澡人人澡人人看| 爽爽淫人综合网网站| 国产成人精品一区二区三区福利| av在线电影网| 色综合天天综合色综合av| 男人女人拔萝卜视频| 日本在线电影一区二区三区| 91精品国产乱码久久久久久久久 | 精品不卡一区二区| 国产99精品在线观看| 在线视频欧美一区| 欧美日韩五区| 亚洲男人第一网站| 国产系列精品av| 国产成人综合网| 潘金莲一级淫片aaaaa免费看| 韩日一区二区| 亚洲欧美在线播放| 国产小视频在线免费观看| 国产精品99久| 中文字幕久久综合| 成人国产精品入口免费视频| 亚洲免费伊人电影在线观看av| 久久亚洲精品大全| 国产成人久久精品77777最新版本| 伊甸园精品99久久久久久| 在线成人视屏| 一区二区欧美日韩视频| 免费看毛片网站| 26uuu精品一区二区| 黄页网站在线观看视频| 福利欧美精品在线| 欧美激情奇米色| 成人小说亚洲一区二区三区| 亚洲宅男天堂在线观看无病毒| 精产国品一二三区| 欧美黄在线观看| 懂色一区二区三区av片| 欧美卡一卡二| 精品国产第一区二区三区观看体验| 久久久久久久久久网站| 国产精一区二区三区| 777久久精品一区二区三区无码 | 在线免费一区| 9999在线精品视频| 欧美激情久久久| 婷婷五月综合激情| 日本a级在线| 成人毛片老司机大片| 国产一线二线三线女| 成人av婷婷| 欧美一级视频免费在线观看| 精品欧美不卡一区二区在线观看| 色噜噜狠狠一区二区三区果冻| 波多野在线播放| 久久99精品国产91久久来源| 国产对白在线播放| 伊人精品综合| 日本韩国欧美精品大片卡二| www黄在线观看| 欧美一卡二卡在线观看| 国产午夜福利精品| 久久久久久久久久久久久久久99| 一本色道久久亚洲综合精品蜜桃| 我不卡伦不卡影院| 国产精品久久久久久免费观看| 免费成人在线电影| 一个人www欧美| 精品人妻一区二区三区换脸明星| 亚洲成人一二三| 国产激情av在线| 国产不卡高清在线观看视频| 国产男女无遮挡| 99视频精品全国免费| 大波视频国产精品久久| 日韩在线免费| 久久99青青精品免费观看| 日韩在线免费看| 91精品欧美综合在线观看最新 | 午夜视频成人| 懂色av中文字幕一区二区三区| 亚洲国产精品成人一区二区| 日韩手机在线观看| 亚洲国产岛国毛片在线| 中文字幕制服丝袜| 日av在线不卡| 黄页免费在线观看视频| 欧美电影三区| 久久66热这里只有精品| 只有精品亚洲| 欧美有码在线观看视频| 国产色在线观看| 亚洲色图激情小说| 韩国av在线免费观看| 欧美无人高清视频在线观看| 四虎永久在线精品| 中文字幕在线视频一区| 在线免费观看成年人视频| 国产精品自产自拍| 欧美精品aaaa| 一区二区91| 国产在线xxxx| 国产精品久久久乱弄| 欧美在线视频一区二区三区| 精品伊人久久久| 91久久精品国产91久久性色tv| 欧美影视资讯| 日韩女优人人人人射在线视频| 国产又色又爽又黄刺激在线视频| 久久国内精品一国内精品| 欧美91精品久久久久国产性生爱| 精品久久人人做人人爱| 97视频免费在线| 欧美亚洲国产一区二区三区va| 久青草视频在线观看| 亚洲日本欧美天堂| 在线观看天堂av| 久久精品视频一区| 精品久久久久久中文字幕人妻最新| 国产99久久久精品| 久久aaaa片一区二区| 狠狠色丁香婷综合久久| 黄色免费网址大全| 丝袜诱惑亚洲看片| 亚洲爆乳无码专区| 欧美亚洲自偷自偷| 免费无码av片在线观看| 中文亚洲欧美| 777久久久精品一区二区三区| 一本色道久久综合亚洲精品高清 | 国产美女在线观看一区| 午夜免费看毛片| 美国一区二区三区在线播放| 免费看涩涩视频| 久久99久久久欧美国产| 五月激情婷婷在线| 精品无人区卡一卡二卡三乱码免费卡| 在线观看的毛片| 久久精品久久综合| 国产又黄又猛的视频| 久久国产精品露脸对白| 日本中文字幕影院| 国模大尺度一区二区三区| 亚洲精品中文字幕乱码无线| 国产高清成人在线| 午夜福利三级理论电影| 成人爱爱电影网址| 先锋资源av在线| 91蝌蚪porny成人天涯| 97超碰在线免费观看| 国产欧美一区在线| 亚洲区一区二区三| 亚洲午夜免费视频| 日日夜夜综合网| 欧美日韩黄色一区二区| 99久久久国产精品无码网爆| 精品噜噜噜噜久久久久久久久试看 | 男女羞羞在线观看| 国产精品成人免费电影| 亚洲老司机网| 国产日韩三区| 精品视频免费| 伊人再见免费在线观看高清版 | 精品日韩视频在线观看| av手机天堂网| 日韩一区二区三区精品视频 | av不卡一区二区三区| 欧美色图亚洲激情| 1000部国产精品成人观看| 久久久久人妻一区精品色欧美| 精品国产乱码久久久久久婷婷| 亚洲图片欧美日韩| 日韩午夜在线影院| 日韩二区三区| 美女性感视频久久久| 日本乱码一区二区三区不卡| 国产三级精品网站| 林ゆな中文字幕一区二区| 四虎一区二区| 影音先锋在线一区| 最新天堂中文在线| 不卡影院免费观看| 欧美性生给视频| 红桃av永久久久| 亚洲天堂网视频| 亚洲精品动漫100p| 麻豆影视在线观看_| 午夜精品久久久久久久99黑人| 成人精品国产亚洲| 精品无人乱码一区二区三区的优势 | 国产成人午夜精品影院观看视频| 少妇无套高潮一二三区| 亚洲成人tv网| av免费在线不卡| 一区二区三区四区在线观看视频 | 国产精品国产亚洲伊人久久| 777久久精品| 日韩视频在线免费播放| 久久激情网站| 男女性杂交内射妇女bbwxz| 国产精品国产精品国产专区不片| 国产区在线观看视频| 日韩欧美一二三区| 瑟瑟视频在线| 国产成人精品国内自产拍免费看| 国产精品成人自拍| 黄色www在线观看| 青娱乐精品视频在线| 蜜桃精品成人影片| 亚洲国产综合色| av免费观看在线| 久久精品视频免费播放| 搜成人激情视频| 日韩av一区二区三区在线 | 日本a级片电影一区二区| swag国产精品一区二区| 国产资源第一页| 国产一区二区剧情av在线| 欧美一区二区三区观看| 欧美亚男人的天堂| 国产视频网站在线| 欧洲精品久久久| 尤物tv在线精品| 成年人视频网站免费观看| www.欧美精品一二区| 久久综合激情网| 亚洲精品一区二区精华| 手机在线免费av| 97超碰人人看人人| 午夜电影亚洲| 国产ts在线观看| 亚洲影视在线播放| 国产自产一区二区| 国内免费精品永久在线视频| 欧美经典影片视频网站| 永久免费网站视频在线观看| 韩国av一区二区三区在线观看| 亚洲AV成人无码精电影在线| 6080日韩午夜伦伦午夜伦| 免费在线观看黄色| 91天堂在线观看| 欧美日韩天堂| 一区二区视频观看| 日本高清不卡在线观看| 成人性爱视频在线观看| 国产精品永久免费视频| 国产精品伦理久久久久久| 中文字幕av一区二区三区人妻少妇| 一区二区三区在线观看动漫| 免费看黄色一级视频| 2019av中文字幕| 精品欧美激情在线观看| 久久久久久久久久久久久久久国产 | 免费看欧美美女黄的网站| 亚洲欧洲综合网| 欧美成人乱码一区二区三区| 妞干网免费在线视频| 欧美综合77777色婷婷| 蜜臀av国产精品久久久久| 朝桐光av在线| 日韩精品视频免费专区在线播放| 欧美三级精品| 久久久久久久免费视频| 成人免费看的视频| 无码人妻av免费一区二区三区 | 精品精品国产高清a毛片牛牛 | 欧美黑人激情| 成人在线视频网址| 久久精品综合| 91麻豆精品成人一区二区| 欧美不卡一二三| 香蕉成人av| 日韩一级片一区二区| 久久综合一区二区| 99久久久国产精品无码免费| 欧美在线观看网址综合| 国产精品久久久久久久久久10秀| 欧美日韩人妻精品一区在线| 欧美亚州韩日在线看免费版国语版| 丝袜综合欧美| 少妇免费毛片久久久久久久久| 国产成人自拍高清视频在线免费播放| 亚洲欧美一区二区三区在线观看| 久久精品国产成人| 九九视频免费观看视频精品| 老女人性生活视频| 欧洲精品一区二区|