Skip to content

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) => {
    // 只允許一個負號開頭、數字、只允許一個小數點且小數點後最多兩位
    // 1. 移除所有非數字、非小數點、非負號
    value = value.replace(/[^\d.-]/g, '')
    // 2. 處理多個小數點與負號
    value = value.replace(/(?!^)-/g, '') // 只允許一個負號且在最前面
    value = value.replace(/(\..*)\./g, '$1') // 只允許一個小數點
    // 3. 用 regex 擷取正確格式:可選負號,數字,可選小數點與最多兩位
    const match = value.match(/^(-)?(\d*)(\.(\d{0,2})?)?/)
    if (!match) return ''
    let result = ''

    if (match[1]) result += '-'
    if (match[2]) result += match[2].replace(/^0+(?=\d)/, '') // 處理前導零
    if (match[3]) result += match[3]
    return result
  }
</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",提升輸入體驗。

參考資料