为什么html表单上的重置按钮不会重置隐藏字段?

tru*_*ity 11 html forms reset hidden-field

我发现了令人惊讶的事情:

<html>
<head>
<script type="text/javascript">
function f()
{
document.getElementById("h").value++;
document.getElementById("x").value++;
}
</script>
</head>
<body>

<form>
<input type="hidden" name="hidden" id="h" value="5"/>
<input type="text" id="x" value="5"/>
<input name='clear' type='reset' id='clear' value='Clear'>
</form>

<button type="button" onclick="f()">Increment</button>
<button type="button" onclick="alert(document.getElementById('h').value)">Show hidden</button>

</body>
</html> 
Run Code Online (Sandbox Code Playgroud)

在Firefox 4.0.1中尝试此操作,单击"清除"始终会将文本输入重置为5,但永远不会重置隐藏字段.

我(和其他人)根本没想到这种行为:我们期望隐藏的值也被重置!

任何人都可以指向解释为什么隐藏输入被重置按钮区别对待的文档或规范?

关于为什么这种行为是可取的解释也是受欢迎的.

tru*_*ity 15

FWIW,我想我可以从答案和评论中整理完整的故事.

使用原理: clear按钮用于清除用户输入,由于隐藏的输入不能由用户直接访问,因此允许用户重置隐藏输入的值是没有意义的.

文档和行为: AR指出 的错误报告明确指出发生了什么:隐藏字段的value模式是默认的,正如规范中所预期的那样.
特别是,这意味着更改值(如问题中的示例代码)更改默认值,重置按钮将输入字段重置为默认值,因此没有更改.
文本输入的行为是不同的(即使它的值也以编程value方式更改),因为它的模式不是默认值而是,这意味着输入的默认值和当前值之间存在区别.


Wil*_*art 6

用户无法看到或修改隐藏字段,因此按下按钮清除它是没有任何意义的.