diff options
Diffstat (limited to 'files')
-rw-r--r-- | files/zh-cn/learn/forms/index.md | 112 |
1 files changed, 59 insertions, 53 deletions
diff --git a/files/zh-cn/learn/forms/index.md b/files/zh-cn/learn/forms/index.md index e4d6f79e6f..b9e2684809 100644 --- a/files/zh-cn/learn/forms/index.md +++ b/files/zh-cn/learn/forms/index.md @@ -2,77 +2,83 @@ title: HTML表单指南 slug: Learn/Forms tags: + - Beginner + - Featured - Forms + - Guide - HTML - - NeedsTranslation - - TopicStub + - Landing + - Learn + - Web translation_of: Learn/Forms -original_slug: Learn/HTML/Forms --- -<div>{{LearnSidebar}}</div> +{{LearnSidebar}} -<p class="summary">这个模块提供了一系列帮助您掌握HTML表单的文章。HTML表单是与用户交互的强大工具;然而,由于历史和技术上的原因,如何充分发挥它们的潜力并不总是显而易见的。在本指南中,我们将介绍HTML表单的所有方面,从结构到样式,从数据处理到自定义小部件。</p> +这个模块提供了一系列帮助您掌握 HTML 表单的文章。HTML 表单是与用户交互的强大工具;然而,由于历史和技术上的原因,如何充分发挥它们的潜力并不总是显而易见的。在本指南中,我们将介绍 HTML 表单的各个方面:结构、样式、验证表单数据,以及提交数据到服务器。 -<h2 id="预备知识">预备知识</h2> +> **标注:** +> +> #### 想成为一名前端网页开发者? +> +> 我们整理了一个课程,其中包含您实现目标所需的所有基本内容。 +> +> [**开始使用**](/zh-CN/docs/Learn/Front-end_web_developer) -<p>在开始这个模块之前,您至少应该完成我们<a href="/zh-CN/docs/Learn/HTML/Introduction_to_HTML">对HTML的介绍</a>。此时此刻,您应该会发现{{anch("基本指南")}}很容易理解,并且能够使用我们的<a href="/zh-CN/docs/Learn/HTML/Forms/The_native_form_widgets">原生表单小部件</a>指南。</p> +## 预备知识 -<p>但是模块的其余部分更高级一些,很容易将表单小部件放在页面上,但是如果不使用高级表单特性、CSS和JavaScript,就不能对它们做太多的工作。因此,在您查看其他部分之前,我们建议您先离开,先学习一些<a href="/zh-CN/docs/Learn/CSS">CSS</a>和<a href="/zh-CN/docs/Learn/JavaScript">JavaScript</a>。</p> +在开始这个模块之前,您至少应该完成我们[对 HTML 的介绍](/zh-CN/docs/Learn/HTML/Introduction_to_HTML)。此时此刻,您应该会发现[基本指南](#基本指南)很容易理解,并且能够使用我们的[原生表单控件](/zh-CN/docs/Learn/HTML/Forms/Basic_native_form_controls)指南。 -<div class="note"> -<p><strong>注意:</strong>如果您正在使用一个不能让您创建自己的文件的计算机/平板电脑/其它设备,那么您可以尝试(大多数)在线编码程序中的代码示例,例如<a href="http://jsbin.com/">JSBin</a>或<a href="https://thimble.mozilla.org/">Thimble</a>。</p> -</div> +然而,掌握表单需要的不仅仅是 HTML 知识——您还需要学习一些特定的技术来设置表单控件的样式,并且需要一些脚本知识来处理诸如验证和创建自定义表单控件之类的事情。因此,在您查看下面列出的其它部分之前,我们建议您先离开,并学习一些 [CSS](/zh-CN/docs/Learn/CSS) 和 [JavaScript](/zh-CN/docs/Learn/JavaScript)。 -<h2 id="基本指南">基本指南</h2> +以上内容明确地说明了为什么我们将 HTML 表单独立放在一个模块中,而不是将其与 HTML、CSS 和 JavaScript 这些模块放在一起——表单元素比绝大多数其它的 HTML 元素都要复杂,并且它们还需要与相关的 CSS 和 JavaScript 技术紧密集合才能充分利用它们。 -<dl> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/Your_first_HTML_form">你的第一个HTML表单</a></dt> - <dd>本系列的第一篇文章提供了您第一次创建HTML表单的经验,包括设计一个简单表单,使用正确的HTML元素实现它,通过CSS添加一些非常简单的样式,以及如何将数据发送到服务器。</dd> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/How_to_structure_an_HTML_form">如何构造HTML表单</a></dt> - <dd>有了基础知识,我们现在更详细地了解了用于为表单的不同部分提供结构和意义的元素。</dd> -</dl> +> **备注:** 如果您正在使用一个不能让您创建自己的文件的计算机/平板电脑/其它设备,那么您可以尝试(大多数)在线编码程序中的代码示例,例如 [JSBin](https://jsbin.com/) 或 [Glitch](https://glitch.com/)。 -<h2 id="什么表单小部件可用">什么表单小部件可用?</h2> +## 基本指南 -<dl> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/The_native_form_widgets">原生表单小部件</a></dt> - <dd>现在,我们详细研究了不同表单部件的功能,查看了哪些选项可用于收集不同类型的数据。</dd> -</dl> +- [你的第一个表单](/zh-CN/docs/Learn/Forms/Your_first_form) + - : 本系列的第一篇文章提供了您第一次创建 HTML 表单的经验,包括设计一个简单表单、使用正确的 HTML 元素实现它、通过 CSS 添加一些非常简单的样式,以及如何将数据发送到服务器。 +- [如何构造 HTML 表单](/zh-CN/docs/Learn/Forms/How_to_structure_a_web_form) + - : 有了基础知识,我们现在更详细地了解了用于为表单的不同部分提供结构和意义的元素。 -<h2 id="验证和提交表单数据">验证和提交表单数据</h2> +## 不同的表单控件 -<dl> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/Sending_and_retrieving_form_data">发送表单数据</a></dt> - <dd>本文讨论当用户提交一个表单时,会发生什么情况——表单数据的去向以及当表单数据到达指定位置时我们如何处理?我们还研究了与发送表单数据相关的一些安全问题。</dd> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/Form_validation">表单数据验证</a></dt> - <dd>发送数据还不够,我们还需要确保数据用户填写表单的格式是正确的,我们需要成功地处理它,而且它不会破坏我们的应用程序。我们还希望帮助用户正确填写表单,在使用应用程序时不要感到沮丧。表单验证帮助我们实现这些目标,本文将告诉您需要了解的内容。</dd> -</dl> +- [原生表单控件](/zh-CN/docs/Learn/Forms/Basic_native_form_controls) + - : 我们从详细了解原始 HTML {{htmlelement("input")}} 元素的类型开始,同时学习在收集不同类型数据时可用的选择。 +- [HTML5 input 的类型](/zh-CN/docs/Learn/Forms/HTML5_input_types) + - : 在这里,我们深入挖掘 `<input>` 元素,了解 HTML5 发布时提供的其它 input 类型,以及它们提供的各种 UI 弓箭和数据收集增强功能。此外,我们可以了解 {{htmlelement('output')}} 元素。 +- [其它表单控件](/zh-CN/docs/Learn/Forms/Other_form_controls) + - : 接下来,我们学习所有 非`<input>` 表单控件,以及相关的工具,如:{{htmlelement('select')}}、{{htmlelement('textarea')}}、{{htmlelement('meter')}} 和 {{htmlelement('progress')}}。 -<h2 id="高级指南">高级指南</h2> +## 表单样式指南 -<dl> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/How_to_build_custom_form_widgets">如何构建自定表单小组件</a></dt> - <dd>在某些情况下,原生表单部件无法提供您需要的东西,例如,由于样式或功能。在这种情况下,您可能需要使用原生HTML构建自己的表单小部件。本文将说明您是如何做到这一点的,以及在实际案例研究中需要注意的事项。</dd> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/Sending_forms_through_JavaScript">通过JavaScript发送表单</a></dt> - <dd>本文将讨论如何使用表单来组装HTTP请求,并通过定制的JavaScript发送它,而不是标准的表单提交。它还研究了为什么要这么做,以及这样做的意义。(请参阅使用FormData对象。)</dd> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/HTML_forms_in_legacy_browsers">遗留浏览器中的HTML表单</a></dt> - <dd>文章覆盖特性检测等。这应该被重定向到跨浏览器测试模块,因为相同的东西在那里被更好地覆盖。</dd> -</dl> +- [HTML 表单样式](/zh-CN/docs/Learn/Forms/Styling_web_forms) + - : 本文介绍了使用CSS的样式表单,包括您可能需要了解的基本样式任务的所有基础知识。 +- [高级表单样式](/zh-CN/docs/Learn/Forms/Advanced_form_styling) + - : 在这里,我们将看到一些更高级的表单样式技术,这些技术需要在处理一些更难以设置样式的元素时使用。 +- [UI 伪类](/zh-CN/docs/Learn/Forms/UI_pseudo-classes) + - : 一个关于在 HTML 表单中使用 UI 伪类以根据表单状态自动设置样式。 -<h2 id="表单样式指南">表单样式指南</h2> +## 验证和提交表单数据 -<dl> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/Styling_HTML_forms">HTML表单样式</a></dt> - <dd>本文介绍了使用CSS的样式表单,包括您可能需要了解的基本样式任务的所有基础知识。</dd> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/Advanced_styling_for_HTML_forms">高级HTML表单样式</a></dt> - <dd>在这里,我们将看到一些更高级的表单样式技术,这些技术需要在处理一些更难以风格的元素时使用。</dd> - <dt><a href="/zh-CN/docs/Learn/HTML/Forms/Property_compatibility_table_for_form_widgets">表单部件的属性兼容性表</a></dt> - <dd>这最后一篇文章提供了一个方便的参考,允许您查看哪些CSS属性与哪些表单元素是兼容的。</dd> -</dl> +- [表单数据验证](/zh-CN/docs/Learn/Forms/Form_validation) + - : 发送数据还不够——我们还需要确保用户填写表单的数据格式是正确的以在后续流程中正确处理它,而且它不会破坏我们的应用程序。我们还希望帮助用户正确填写表单,让他们在使用应用程序时不会感到困扰。表单验证帮助我们实现这些目标,本文将告诉您需要了解的内容。 +- [发送表单数据](/zh-CN/docs/Learn/Forms/Sending_and_retrieving_form_data) + - : 本文讨论当用户提交一个表单时,会发生什么情况——表单数据的去向,以及当表单数据到达指定位置时我们如何处理?我们还研究了与发送表单数据相关的一些安全问题。 -<h2 id="另见">另见</h2> +## 高级指南 -<ul> - <li><a href="/zh-CN/docs/Web/HTML/Element#Forms">HTML forms element reference</a></li> - <li><a href="/zh-CN/docs/Web/HTML/Element/input">HTML <input> types reference</a></li> -</ul> +以下文章对于学习路径来说没那么重要,但是当你掌握了上述技术并向了解更多内容时,它们会变得有趣且实用。 + +- [如何构建自定义表单控件](/zh-CN/docs/Learn/Forms/How_to_build_custom_form_controls) + - : 在某些情况下,原生表单部件无法提供您需要的东西,例如,由于样式或功能。在这种情况下,您可能需要使用原生 HTML 构建自己的表单小部件。本文将说明您是如何做到这一点的,以及在实际案例研究中需要注意的事项。 +- [通过 JavaScript 发送表单](/zh-CN/docs/Learn/Forms/Sending_forms_through_JavaScript) + - : 本文将讨论如何使用表单来构建 HTTP 请求,并通过定制的 JavaScript 发送它,而不是标准的表单提交。它还说明了为什么要这么做,以及这样做的意义。(请参阅[使用 FormData 对象](/zh-CN/docs/Web/API/FormData/Using_FormData_Objects)。) +- [表单控件的 CSS 属性兼容性表](/zh-CN/docs/Learn/Forms/Property_compatibility_table_for_form_controls) + - : 最后一篇文章提供了一个方便的参考,让您可以确定 CSS 属性与表单元素的兼容性关系。 + +## 参见 + +- [HTML 表单元素](/zh-CN/docs/Web/HTML/Element#表单) +- [HTML \<input> 元素](/zh-CN/docs/Web/HTML/Element/Input) +- [HTML 属性](/zh-CN/docs/Web/HTML/Attributes) |