HTML 属性:min
min
属性定义了可接受和有效的输入最小值。如果元素的 value
小于此值,则该元素将无法通过验证。此值必须小于等于 max
属性的值。
某些输入类型具有默认的最小值。如果输入项没有默认的最小值,且 min
指定的值无法转换为有效的数字(或未设置最小值),则输入没有最小值。
以下输入类型支持该属性:date、month、week、time、datetime-local、number 和 range 类型,以及 <meter>
元素。
语法
输入类型 | 语法 | 示例 |
---|---|---|
date | yyyy-mm-dd |
<input type="date" min="2019-12-25" step="1"> |
month | yyyy-mm |
<input type="month" min="2019-12" step="12"> |
week | yyyy-W## |
<input type="week" min="2019-W23" step=""> |
time | HH:mm |
<input type="time" min="09:00" step="900"> |
datetime-local | yyyy-mm-ddTHH:mm |
<input type="datetime-local" min="2019-12-25T19:30"> |
number | <number> | <input type="number" min="0" step="5" max="100"> |
range | <number> | <input type="range" min="60" step="5" max="100"> |
备注:
当用户输入的数据不符合设置的 min 值时,该值在约束验证中被视为无效,并会匹配 :invalid
和 :out-of-range
伪类。
参阅客户端验证和 rangeUnderflow
获取更多信息。
对于 <meter>
元素,min
属性定义了测量范围的最小数值边界。若指定,则该值必须小于最大值(max
属性)。在两种情况下,如果省略,则默认值为 1。
对 step 的影响
min
和 step
的值决定了有效的值范围,即使未包含 step
属性,step
也会默认取值为 1
。
我们可以为无效输入添加一个红色边框:
input:invalid {
border: solid red 3px;
}
然后定义一个最小值为 7.2 且省略了 step 属性的输入元素,此时 step 默认值为 1。
<input id="myNumber" name="myNumber" type="number" min="7.2" value="8" />
由于 step
的默认值为 1,因此有效值包括 7.2
、8.2
、9.2
等。而值 8 是无效的。由于我们包含了无效值,支持的浏览器将显示该值为无效。
如果没有明确指定,number
和 range
类型的 step
默认值为 1,而日期、时间输入类型的 step
默认值为 1 个单位(秒、周、月、天)。
无障碍考虑
提供说明以帮助用户理解如何填写表单及使用各个表单控件。指明必填和可选输入、数据格式及其他相关信息。在使用 min
属性时,确保用户理解该最小值要求。将说明放置在 <label>
标签内通常即可满足需求。如果需要在标签之外提供上述说明以实现更灵活的布局设计,请考虑使用 aria-labelledby
或 aria-describedby
。
规范
Specification |
---|
HTML Standard # attr-input-min |
HTML Standard # attr-meter-max |
浏览器兼容性
html.elements.input.min
BCD tables only load in the browser
html.elements.meter.min
BCD tables only load in the browser