【发布时间】:2011-05-30 00:03:01
【问题描述】:
我可以将<form> 标记放在另一个<form> 标记中吗?
例如:
<form>
<form>
</form>
</form>
【问题讨论】:
-
你的意思是一个表单元素 ;-)
-
是的,我的意思是表单标签,谢谢我得到答案
我可以将<form> 标记放在另一个<form> 标记中吗?
例如:
<form>
<form>
</form>
</form>
【问题讨论】:
不,嵌套表单是被禁止的。
这在 HTML 4.01 DTD 中表示为:
<!ELEMENT FORM - - (%block;|SCRIPT)+ -(FORM) -- interactive form -->
——http://www.w3.org/TR/html4/interact/forms.html#h-17.3
这意味着一个 FORM 有一个强制的开始标签,强制的结束标签,并且可以包含 %block 或 SCRIPT 中的任何内容,除了其他 FORM。
XML DTD 不像 SGML DTD 那样具有表现力,因此在 XHTML 中,此规则仅在规范的人类可读文本中指定:
表单不得包含其他表单元素。
——http://www.w3.org/TR/xhtml1/#prohibitions
HTML 5 不是 SGML 应用程序,也没有该语言的官方机器可读描述。它也在文字中表达了这个规则:
内容模型:
流式内容,但没有表单元素后代。
【讨论】:
适用于 XHTML 1.0 Strict。
我什至通过将以下内容粘贴到 http://validator.w3.org/check 来测试验证。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Markup Test</title>
<meta http-equiv="Content-Type" content="application/xhtml+xml; charset=utf-8" />
</head>
<body>
<h1>Markup Test</h1>
<p>
This doc contains a form with a nested form and validates at
<a title="Validate using W3C Markup Validation Service" href="http://validator.w3.org/check?uri=referer">
http://validator.w3.org/
</a>
</p>
<form action="#">
<div>
<form action="#">
</form>
</div>
</form>
</body>
</html>
但是下面的 Quentin 是正确的:我测试并忽略了打开 和 结束标记的嵌套表单。出现在子表单标记之前、内部和之后的表单输入元素被视为父表单的成员,包括提交按钮。子表单中对 this.form 的 JavaScript 引用引用父表单。如果你给子表单一个 id 并通过getElementById 检索它,那么你会得到一个元素,但.submit() 什么都不做。它基本上是一种形式(父级),其中包含垃圾标签。
【讨论】:
不允许直接在表格内。您的所有 javascript 都将不起作用,并且预期的行为将不存在。
不过,你可以试试这个:
<form name ="1st form">
<...>
<div> <form id="dummy"></form></div>
<...>
<form name = "2nd form">
</form>
<...>
</form>
您需要在您打算使用的 2 个表单之间创建一个虚拟表单。 1 注意事项,1st Form 和 dummy form 之间需要有一些标签。否则这将不起作用。
【讨论】:
你不能嵌套它们,但你可以对元素进行分组...有一个专门用于此的机制,the <fieldset> element,用于对控件/标签进行分组...在 HTML5 中将其与特定表单相关联,禁用内容,等等
【讨论】:
规范不允许嵌套表单(我不确定尝试时会出现什么行为,我没有尝试过)。
不过,a previous question 中有一些关于该主题的有趣讨论。
【讨论】:
不,如果您想拆分表单,请使用<fieldset>。一些浏览器可能能够解析它(没有测试过),但根据 w3 标准,不允许在其他表单中使用表单。
【讨论】: