亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

如何使HTML5數字輸入僅接受整數

發布時間:2021-09-18 13:38:40 來源:億速云 閱讀:258 作者:小新 欄目:web開發

這篇文章給大家分享的是有關如何使HTML5數字輸入僅接受整數的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

整體概念是合理的:使用HTML 5屬性來限制可以發送到服務器的內容,然后使用Javascript增強它,以限制用戶可以在第一個地方輸入的內容。

所以讓我們來看看這些問題,并更好地實現它。

問題1,不好的腳本

最常見的缺陷是缺乏適當的降級功能。  如果您要在“electron”或“nw.js”中構建完整的堆棧應用程序,那很好,但是這種形式的東西通常在面向公眾的網站中沒有位置。

就像我經常說的那樣,高質量的腳本應該增強已經在工作的頁面,而不是用戶使用它的唯一方法。

解決辦法?

使用 pattern 和 step 屬性來限制有效內容。

問題2,正則表達式模式錯誤或不完整

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

它還可能出現問題,因為某些實現“不是”正則表達式,這會導致誤報。

解決辦法?

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

對于JavaScript,只使用正則表達式來測試數字,并應用一些更實用的邏輯來檢測其他值。

簡單易行!

問題3,在標記中使用事件屬性

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

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

這也意味著您沒有完整/適當的事件處理程序訪問權限。

解決辦法?

Element.addEventListener,請使用它!

問題4,必須對每個輸入進行硬編碼

無論是通過問題3將事件屬性放到標記中,還是通過手動獲取唯一ID來捕獲它們,我幾乎沒有發現可以實際使用即插即用的標記應用程序的代碼庫!

解決辦法?

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

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

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

解決辦法?

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

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

HTML:

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

只接受整數,如果你想只接受正數,可以換成 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中以隔離范圍。 然后,抓取我們要在頁面上掛接的所有輸入,并創建我們的正則表達式。

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

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

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

如果它是一個負號和第一個字符,通過return允許它。

如果它是一個數字,通過return允許它。

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

Live Demo

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

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

如何使HTML5數字輸入僅接受整數

懸而未決的問題

我可能會考慮添加的一件事是掛鉤“change”事件來攔截粘貼,但由于“pattern”屬性不允許提交無效的值,所以應該沒有問題。

感謝各位的閱讀!關于“如何使HTML5數字輸入僅接受整數”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

建阳市| 雷山县| 昌图县| 邵阳市| 揭西县| 肇州县| 安岳县| 云霄县| 巴中市| 台湾省| 云和县| 都江堰市| 阜康市| 盐城市| 阿克陶县| 天门市| 隆昌县| 金塔县| 祁连县| 新竹县| 且末县| 宜川县| 岑溪市| 舞钢市| 松滋市| 建湖县| 辽源市| 湾仔区| 新龙县| 济南市| 高碑店市| 荃湾区| 乐昌市| 嵊州市| 衡水市| 永川市| 山东省| 壤塘县| 四子王旗| 电白县| 砚山县|