input 只能輸入數字且小數點最多兩位
這份文件說明如何在前端限制 <input>
欄位只能輸入數字,並且小數點後最多兩位,適用於表單驗證與資料輸入場景。
使用 JavaScript 驗證(最推薦,僅輸入時即時限制)
html
<input id="numInput" type="text" inputmode="decimal" />
<script>
document.getElementById('numInput').addEventListener('input', function (e) {
e.target.value = formatDecimal(e.target.value)
})
const formatDecimal = (value: string) => {
return value
.replace(/[^\d.-]/g, '')
.replace(/(?!^)-/g, '')
.replace(/(\..*)\./g, '$1')
.replace(/^(-?\d*\.\d{0,2}).*$/, '$1')
.replace(/^(-?)0+(\d)/, '$1$2')
}
</script>
- 這個驗證邏輯是綁定在 input 事件上,代表每次使用者輸入時(包含貼上、刪除、輸入新字元等),都會即時套用格式化,確保欄位內容始終符合規則。
其他可行方法
1. 使用 pattern 屬性(僅前端驗證)
html
<input type="text" pattern="^-?\\d*(\\.\\d{0,2})?$" inputmode="decimal" />
- 這種方式僅在表單送出時驗證,無法即時限制輸入,也無法防止貼上不符格式的內容。
2. 使用 type="number" 搭配 step、min、max
html
<input type="number" step="0.01" min="0" max="999999" />
- 這種方式可限制小數點位數,但不同瀏覽器行為不一致,且仍可輸入不符格式的內容。
3. 使用第三方套件
- 例如 cleave-zen (Cleave.js) 等,可快速套用格式化規則,適合複雜需求。
其他注意事項
- 行動裝置建議加
inputmode="decimal"
,提升輸入體驗。