溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么讓HTML5數(shù)字輸入僅接收整數(shù)

發(fā)布時(shí)間:2021-09-18 13:47:46 來源:億速云 閱讀:115 作者:小新 欄目:編程語言

這篇文章主要介紹了怎么讓HTML5數(shù)字輸入僅接收整數(shù),具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

問題 1,不好的腳本

最常見的缺陷是缺乏適當(dāng)?shù)慕导壒δ?。如果您要在“electron”或“nw.js”中構(gòu)建完整的堆棧應(yīng)用程序,那很好,但是這種形式的東西通常在面向公眾的網(wǎng)站中沒有位置。

就像我經(jīng)常說的那樣,高質(zhì)量的腳本應(yīng)該增強(qiáng)已經(jīng)在工作的頁面,而不是用戶使用它的唯一方法。

解決辦法?

使用 pattern 和 step 屬性來限制有效內(nèi)容。

問題 2,正則表達(dá)式模式錯(cuò)誤或不完整

人們最常用的模式是 [-/ d] *,它的問題是允許在任何地方都減號。雖然肯定可以使用 type = “number”  來解決問題,但這不是一個(gè)好選擇。截取按鍵時(shí)更是如此,因?yàn)闇p號只能是第一個(gè)字符。

它還可能出現(xiàn)問題,因?yàn)槟承?shí)現(xiàn)“不是”正則表達(dá)式,這會導(dǎo)致誤報(bào)。

解決辦法?

對于 HTML,使用更好的表達(dá)式:^[- d]\d*$ 更加健壯和準(zhǔn)確。減號可以是匹配開始的第一個(gè)字符,然后是零個(gè)或多個(gè)小數(shù),直到字符串結(jié)束。

對于 JavaScript,只使用正則表達(dá)式來測試數(shù)字,并應(yīng)用一些更實(shí)用的邏輯來檢測其他值。

簡單易行!

問題 3,在標(biāo)記中使用事件屬性

我知道在 JSX 垃圾中,有大量的用嘴呼吸的人在鼓勵這一點(diǎn),但如果你在寫 vanilla 或其他系統(tǒng),請出于對圣誕節(jié)的愛,從 1997  年的直腸中取出你的頭顱。

將 “onkeypress” 或 “onchange” 放在標(biāo)記中意味著錯(cuò)失了一次緩存機(jī)會,也違反了分離關(guān)注的原則。以這種方式將 JavaScript  放進(jìn)標(biāo)記中,就像在 HTML 4 Strict 中被廢棄的所有東西一樣,愚蠢得令人發(fā)指。就像如果你要用 “text-white box-shadow  col-4-s” 這樣的屬性在你的 HTML 上撒尿一樣,請你承認(rèn)失敗,然后回到寫 HTML 3.2 的時(shí)候,用所有那些 FONT / CENTER  標(biāo)簽、COLOR、BGCOLOR、SIZE、BORDER 和 ALIGN 屬性,以及 "用于布局的表格 "來寫,你們似乎都很清楚地、很珍視地錯(cuò)過了。

這也意味著您沒有完整/適當(dāng)?shù)氖录幚沓绦蛟L問權(quán)限。

解決辦法?

Element.addEventListener,請使用它!

問題 4,必須對每個(gè)輸入進(jìn)行硬編碼

無論是通過問題 3 將事件屬性放到標(biāo)記中,還是通過手動獲取唯一 ID 來捕獲它們,我?guī)缀鯖]有發(fā)現(xiàn)可以實(shí)際使用即插即用的標(biāo)記應(yīng)用程序的代碼庫!

解決辦法?

document.querySelectorAll('input[type="number”][step="1"]')  給我們提供所有我們想要的整數(shù)輸入,所以我們可以增強(qiáng)它。

問題 5,一些腳本阻止使用導(dǎo)航控制和正常編輯!

通過攔截并只允許減號和 0...9,它們可以防止退格鍵、回車鍵、制表鍵、箭頭、刪除、插入等等等等。并不是所有的瀏覽器都會把這些作為 event.key  發(fā)送,這要看你鉤住的是什么事件。比如 “keypress” 事件在 Firefox 和 Chrome 中會過濾掉一些,以免破壞正常的表單使用,但 “老  Edge” 和 Safari 不會,“keydown” 則什么也不過濾。

解決辦法?

因?yàn)?“keypress” 事件跨瀏覽器不一致,所以用 keydown 代替。那么我們就可以利用所有控制鍵在 Event.key  值中返回多個(gè)字符的事實(shí),我們只需要檢查 Event.key.length>1 就可以說 “繼續(xù)允許這些”。

正如前面所提到的,我們所需要的只是一個(gè)簡單的輸入,在不使用 JavaScript 的情況下,它首先具有盡可能多的功能!

HTML:

<input type="number" step="1" pattern="^[-/d]/d*$" />

只接受整數(shù),如果你想只接受正數(shù),可以換成 pattern="/d+”

JavaScript:

然后我們可以使用 JavaScript 來限制用戶的輸入,這樣人們甚至不允許輸入無效值。

(function() {   var integers = document.querySelectorAll(       'input[type="number"][step="1"]'     ),     intRx = /\d/;    for (var input of integers) {     input.addEventListener("keydown", integerChange, false);   }    function integerChange(event) {     if (       event.key.length > 1 ||       (event.key === "-" &&         event.currentTarget.value.length === 0) ||       intRx.test(event.key)     )       return;     event.preventDefault();   } })();

我們首先將其包裝在 IIFE 中以隔離范圍。然后,抓取我們要在頁面上掛接的所有輸入,并創(chuàng)建我們的正則表達(dá)式。

我在事件開始處而不是在事件內(nèi)部創(chuàng)建正則表達(dá)式,這樣我們就不用浪費(fèi)時(shí)間在每個(gè)該死的按鍵上創(chuàng)建它。這就是匿名函數(shù)可能帶來開銷的地方,也是需要告訴那些“函數(shù)式程序員”和他們的“副作用”廢話的地方。

循環(huán)遍歷所有輸入,并為它們分配事件處理程序。

上述處理程序只是檢查我們的返回情況。像箭頭、退格鍵、回車鍵等控制鍵都會返回完整的文字來描述它們,所以如果 event.key  的長度>1,我們就不要阻止這些。

如果它是一個(gè)負(fù)號和第一個(gè)字符,通過 return 允許它。

如果它是一個(gè)數(shù)字,通過 return 允許它。

如果都不是,請阻止該事件。

Live Demo

這是一個(gè)代碼本,它包括幾個(gè)文本字段和多個(gè)整數(shù)和非整數(shù)的數(shù)字字段,所以你可以看到它確實(shí)只鉤住了我們想要的字段。

https://codepen.io/jason-knight/pen/QWGyrwq

怎么讓HTML5數(shù)字輸入僅接收整數(shù)

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“怎么讓HTML5數(shù)字輸入僅接收整數(shù)”這篇文章對大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI