How to use a pattern on an input[type=“number”]?

前端 未结 2 898
温柔的废话
温柔的废话 2021-01-21 07:30

I want the default value to be 0 and recolor the input if it\'s more than 0, using :valid. Am I doing something wrong? Is Google Chrome wrong? Or the HTML5 specific

相关标签:
2条回答
  • 2021-01-21 08:07

    Citing MDN on the pattern property (highlighting added):

    pattern

    A regular expression that the control's value is checked against. The pattern must match the entire value, not just some subset. Use the title attribute to describe the pattern to help the user. This attribute applies when the value of the type attribute is text, search, tel, url or email; otherwise it is ignored. The regular expression language is the same as JavaScript's. The pattern is not surrounded by forward slashes.

    Interestingly I can't find any mentioning of that in both W3C and WhatWG standards.

    0 讨论(0)
  • 2021-01-21 08:16

    I see that if you give the minimum value of 1, the color is not green for 0. The color changes to green when you enter 1. I think that is what you are expecting, right?

    Basically, you can use min and max values for validation purpose. I don't think you need pattern for this.

    <input max="100" min="1" type="number" value="0" />
    

    There is one limitation here. If you leave the field empty, it is still green!

    0 讨论(0)
提交回复
热议问题