整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

8个简单且包容的表单设计技巧请查收

8个简单且包容的表单设计技巧请查收

辑导语:在工作中我们时常会遇到一些关于表单优化的问题,虽然表单听起来是比较简单而常见的设计要素,但要想设计出简洁直观,清晰明了的表单还需要考虑更多的细节因素。本文总结了如何设计出简单且包容的表单的一些技巧,希望对你有所启发。

最近我的工作涉及一项艰巨的任务——如何为我的产品设计出体验更好的表单。当我接到这个任务时,我根本不知道好的表单和坏的表单有什么区别。我需要思考:我应该设计一个多步骤的表单还是一个单页的表单?我应该使用占位符吗?如何使我的表单更符合包容性设计的原则呢?

几乎每一个在网页端发生的重要交互,从注册登陆、购买产品服务到发起客户帮助或者获得反馈,都需要通过表单来完成。因此,虽然表单可能不是设计中最激动人心的设计元素,但学会如何设计一个好的表单是一项非常有价值的技能。

在学习了一些资料之后,我把我认为最好的最有效的表单设计进行了罗列。然而,我们需要记住的是:表单是一个高度依赖上下文的设计元素,所以在实际操作中是有例外的,设计师需要具体情况具体分析。在我们开始之前,让我们快速的来回顾一下表单的五个主要元素:

  • 结构:表单的布局以及表单项的顺序
  • 输入框:文本框、单选或者是多选等界面元素
  • 输入框标签:输入框的相应提示文案
  • 行动按钮:用户执行一个操作,比如提交他们的个人信息
  • 反馈:让用户意识到自己的提交是否成功,反馈可以是视觉暗示也可以是听觉暗示

一、让表单尽量保持单列

多列表单容易让人产生误解:用户非常容易忽略一些必填的内容把信息填入错误的文本框或者完全放弃填写表单。下面的图片展示了用户面对多列表单时视线是如何移动的。

当一个表单没有提供清晰的填写路径时,用户需要很长时间去理解它,更别说去完成它了。当一个表单的填写路径是线性的,比如说单列表单,用户在完成时就不会存在误解。

二、流程、顺序和分组

1. 去掉所有非重要的输入

确保只让用户输入我们真正需要的内容。但是记住,你让用户输入的信息越多,用户就越不想填写这个表单,因此,这会影响转化率等因素并导致销售损失。设计师需要明确让用户填写这一条信息的目的是什么。在这里,我们可以使用一个叫做“问题协议”的系统方法,来确定表单的内容。

2. 用清晰的逻辑排列表单项

好的表单就是在正确的时间向用户询问正确的信息否则它可能会让用户失去兴趣。回忆一下我们自己线上购物的场景:如果网站需要你在购买东西之前就填写付款信息,你会怎么想?或者必须在填写名字之前填写地址?因此,我们要尝试从用户的视角来思考如何建立表单的排列逻辑。

3. 将表单项分组

创建有逻辑的表单项分组帮助用户更清晰的理解信息,这是因为用户只能同时关注在一个群组上,而不是被无数杂乱的信息打乱。被分在一个组的信息代表着它们彼此之间是有关联的,因此,如何在视觉上区分开不同的群组也是很重要的,比如在群组之间添加空白区域。

三、使用清晰有效的标签

首先,标签应该尽量使用顶部对齐,根据眼动测试研究,把标签放在输入框的上面而不是旁边,会帮助用户更快地理解信息。

从包容性设计的角度来看,标签也非常重要。视力正常的用户可以阅读它们,视障用户可以在屏幕阅读器的帮助下听到它们,运动障碍用户可以在更大的点击区域内使用它们。

四、避免使用占位符文本

因为占位符在 HTML 的规范中并不意味着是用户一定要去阅读的内容。占位符之所以被运用在表单中是因为它在用户输入信息的时候提供了额外的指导。但是问题在于这些文本是灰色的,低对比度的颜色使用户很难去阅读。在包容性设计的研究中发现,占位符经常被浏览器的自动翻译功能或者一些屏幕阅读器忽略掉,并不会翻译或者阅读它们。

所以我们为什么要使用占位符呢?使用占位符的原因是因为它们在视觉上节省了大量空间。但问题在于,当用户点击时,占位符会自动消失,所以用户无法二次检查他们是否在正确的输入框中输入了正确的内容。

一个通用的解决方法是使用悬浮的标签把标签作为占位符使用。当用户开始在一个表单项进行输入的时候,标签会悬浮在输入框的上方,这种方式受到欢迎的原因是可以节省空间,总体而言,这是一种非常优雅、自然的模式。

然而,悬浮标签的缺点多于优点。首先,缺少空间来设置提示文字,因为标签和占位符是相同的。第二,标签比较小,以及它较低的对比度让用户很难区分是占位符文字还是真实的数值,最后,在空间的节省上也不会特别多因为标签需要空间进行移动

所以我们该如何做呢?我们可以把提示文字放在输入框的上方,就像下图中这样。因此,屏幕阅读器就不会跳过这些文字,同时它也提供了一个较大的点击区域。

五、标注可选或者必填的输入框

按照惯例,我们习惯用一个红色的星号来代表必填表单项,但是如果你了解我在上文中提到的“问题协议”工具,那么大部分的表单项都是必须要填写的。因此,帮用户标注出可选的输入框会更加方便有意义。当我们想让一些元素脱颖而出时,我们会利用视觉设计来凸显这个元素是不同的。

对于设计师来说,我们可以快速理解红色星号的含义,但是总有人会对此表示疑惑。在标签中加入“可选”的文字,会比用视觉符号更加清晰明确。

在包容性设计中有关于如何用红色星号作为必填字段的建议:可以在表单中添加标记,以便让屏幕阅读器在阅读时,说出“这是一个必填表单项”的语,进而帮助用户理解。

六、 发生错误时,提供反馈

当用户提交的内容出现错误,并且需要告知用户时,在界面上需要有三个方面的呈现。

1. 网页标题中显示发生错误数量

在 html 网页中,出现在浏览器标题栏的标题是用来定义网页的名称的,标题是当屏幕浏览器开始阅读时第一个需要阅读的部分,因此,在这里展现“用户提交的信息有误”能最有效最快捷得反馈给用户

这个解决方法需要用 javascript 来计算表单当中的错误并且体现出来,所以说这可能并不属于一个设计师的职能范围,你只需要确保将此功能告知开发人员。

2. 在表单开头显示错误提示总结

这种类型的错误反馈是更加清晰明确的。在表单上面显示错误的总结,因此用户就知道他具体需要修改哪部分的内容。

一个好的错误总结不仅仅有错误信息还包含了错误位置的链接。错误位置的链接让用户快速跳转到表格中填写错误的部分,而不是让用户先记住哪里发生了错误,再从头阅读一遍表单,从大量信息中取寻找他们的错误之处。

当然,当没有错误出现时,错误总结模块就需要被隐藏了。

3. 实时提醒错误

在一个理想的情况下,所有的错误提醒都是实时的,这意味着当用户填写完一个表单项(或不填写)的时候,就会在表单项附近出现一个错误提示文本,这可以有效的减少用户滑上滑下去寻找错误提示信息的时间

最近也有一种趋势,是将错误提示信息放在文本框的上方,这是因为一些自动填充功能也许会遮挡这些提示,手机上的键盘也会遮挡住这些关键信息,用户很容易忽视掉。

对于稍微复杂一点的表单输入,比如说输入一个新的密码。好的解决方案是用实时的提示来展示密码的强弱程度,也就是说,在用户正在输入的时候,就可以实时展示出目前密码的强弱程度。这将最有效地让用户知道他们是否满足了这个表单的填写要求。

七、行动按钮

1. 在行动按钮上使用动词

CTA 行动按钮应该使用描述性的语言而不是模糊的语言。动词会帮助用户理解接下来会发生什么。虽然行动按钮上的描述应该是简短的,但是也不能因此牺牲语言的清晰性。一定要使用让每个人都理解的语言。

2. 主要按钮与次要按钮

主要按钮和次要按钮之间做明显的视觉区分主要是为了避免用户按下错误的按钮,视觉上的区别可以引向最预期的操作。

3. 行动按钮的位置

一般情况下,提交按钮最应该被放置在表单的底部,因为大多数用户都会从上往下填写表单然后提交表单。另外一个需要思考的点是按钮对齐的位置是向左对齐,向右对齐还是居中对齐。我觉得更好的方案是向左对齐,因为表单中的标签也是向左对齐的,所以当用户将视线向下移动时,他们也会自然的看向这个位置。

在需要使用返回按钮的表单中,比如多步骤表单,提交按钮仍然应该向左对齐,然而返回按钮应该被放置在表单的顶部,这样可以帮助用户区分主要按钮(即提交按钮)和次要按钮(即返回按钮),有助于用户误点击返回按钮。

八、如果内容复杂,可以使用多步骤表单

当表单中所填的内容可以被分类时使用多步骤表单可以提升表单的可用性。让一个较长的表单被分成几个较短的表单可以帮助用户更清晰得填写表单。当表单中要填写的信息较多时,最好使用多步骤表单。同时,也可以向用户展示填写的进度这是提高用户参与度的好方法

进度指示器将表单内容分成多个有逻辑,有顺序的步骤来向用户展示当前的进度。这给用户传达了清晰的反馈,让用户知道他们已经完成了多少内容,以及多少内容还没有完成。

然而,除非你很确定整个表单一共有几个步骤,并且毫无偏差,不然不要用数字去标识,反而会引发更多得疑惑。

1. 尽早且频繁地测试设计稿

最后,设计师需要证明每一个表单元素存在的必要性。表单对于用户来说是乏味的,但是设计师的任务是让表单变得尽可能的可用和易用。像其他设计一样,表单也可以通过测试来不断优化,所以说尽早测试,频繁测试,让测试的结果推动下一次的设计提升。

欢迎大家自由评论,点赞或者分享。

作者:Omar Andani;译者:王英睿;审校:李泽慧、张聿彤;编辑:孙淑雅

原文链接:https://uxdesign.cc/8-ways-to-make-forms-more-user-friendly-50f3f22c708c

本文由@TCC翻译情报局 翻译发布于人人都是产品经理,未经许可,禁止转载。

题图来自 Unsplash,基于CC0协议。

多数PHP程序都使用HTML表单从用户那里获取数据并计算结果。

HTML表单的一些基本原则

  • 选择适合于收集的数据类型和提供交互方式的控件。
  • 清楚标记每一个控件,这样用户就可以理解其功能。
  • 尽可能将标签对齐。将控件的左边缘对齐。
  • 将相关的标签分组,并且通过设计中使用空白将每一个分组分开。
  • 表单上的控件顺序应该类似于用户操作他们的顺序。

创建基本HTML表单

首先创造一个基本的HTML大纲,包含表单控件;然后将控件进行合并(HTML表单必须包括一个提交按钮,用户单击它可以将表单数据发送到服务器。)一个单独的HTML页面可以包含多个表单。

  • 创建HTML结构

包含表单的HTML结构和和普通的HTML结构一样。

<HTML>
  <HEAD>
  <TITLE>标题放在这</TITLE>
  </HEAD>
<BODY>
  表单页面放在这
  </BODY>
  </HTML>

在包含表单的HTML页面中可以使用任何HTML标签。基本的表单使用FROM标签来说明。该标签中METHOD属性接收GET或POST两个值中的一个。ACTION属性子明PHP脚本的url,该脚本可以收集通过表单收集的数据,可以是绝对路径或者相对路径

<FORM METHOD="method" ACTION="url"> 
  中间可以放置表单控件
  </FORM>
  • 合并控件

两个常用的基本控件:文本框和提交按钮。

文本框:允许用户键入信息以发送给PHP脚本。NAME属性为文本提供名称,PHP脚本可以通过名称准确访问其内容,因此它应该是唯一的且符合PHP变量命名规则(但不需要$符号),单标签。VALUE属性指明出现在提交按钮上面的标题。创建方式如下:

<INPUT TYPE="TEXT" NAME="text">

提交按钮:允许用户将一个表单的内容发送到服务器,一个HTML表单对应应该有一个提交按钮。

示例:一个完整的HTML表单。

<HTML>
  <HEAD>
  <TITLE>标题</TITLE>
  </HEAD>
<BODY>
<FORM METHOD="POST" ACTION="phpinfo.php">
<INPUT TYPE="TEXT" NAME="user_name">
<BR/>
<BR/>
<INPUT TYPE="TEXT" NAME="user_email">
<BR/>
<BR/>
<INPUT TYPE="SUBMIT" VALUE="Send the Data">
</FORM>
  </BODY>
  </HTML>


  • 使用多个表单

可以在一个HTML页面中包含多个表单,注意下一个表单的FORM开始之前需要结束前一个FORM表单。

<HTML>
  <HEAD>
  <TITLE>标题</TITLE>
  </HEAD>
<BODY>
  
<FORM METHOD="POST" ACTION="phpinfo.php">
<INPUT TYPE="TEXT" NAME="user_name">
<BR/>
<BR/>
<INPUT TYPE="TEXT" NAME="user_email">
<BR/>
<BR/>
<INPUT TYPE="SUBMIT" VALUE="Send the Data">
<BR/>
<BR/>
</FORM>

<FORM METHOD="POST" NAME="phpinfo.php">
<INPUT TYPE="TEXT" NAME="user_name1">
<BR/>
<BR/>
<INPUT TYPE="TEXT" NAME="user_email1">
<BR/>
<BR/>
<INPUT TYPE="SUBMIT" VALUE="Send the Data1">
</FORM>

  </BODY>
  </HTML>


创建表单控件

  • 创建自定义的文本框

文本框的属性中,TYPE和NAME是必须的,其余是可选属性。SIZE属性用于设置文本框的可视大小;MAXLENGTH指明用户键入字符的最大长度;VALUE给出了一个最初显示在文本框中的值。

<input type="text" name="" size="" maxlength="" value="">
  • 创建文本区域

文本区域可以输入多行文本。NAME和ROWS属性是必须的。ROWS属性表明了文本区域内可以看到的文本行数,充满时会滚动。COLS属性指明可见文本列数与行数类似。WRAP属性指明文本区域内单词换行的方式,可以指定如下值。该标签为双标签。

说明

off

禁止单词换行但用户可以输入换行符强制换行

virtual/soft

各行显示为换行,但是换行并没有被发送到服务器

physica/hard

启用了单词换行

<inputarea name="" rows="" cols="" wrap="">
  • 创建密码框

创建密码框的语法与文本框相同,但要将TYPE属性指定为PASSWORD而不是TYPE。

<input type="password" name="" size="" maxlength="" value="">
  • 创建复选框

取两个值中的一个,即二选一。TYPE属性是必须的,checked属性出现,该复选框默认情况会被选定。value属性指定复选框被选定情况下被发送到服务器的值,默认发送on值。法如下:

<input type="checkbox" name="" checked value="">
  • 创建单选按钮

语法与复选框属性含义相同,但是TYPE属性的值必须是RADIO,NAME属性是必须的。

<input type="radio" name="" checked value="">
  • 创建列表框

用户可以选择一个或者多个选项,它是一个滚动菜单。

<select name="" multipile size="">options go here</select>

name属性是必须的,multipile属性指明用户可以通过按下crtl键并单击多个选项来选择它们

列表框的单选行为可作为单选按钮。

<option selected value="text"></options>
  • 创建隐藏域
<input type="hidden" name="text"value="">
  • 实现上传文件的HTML表单
<input type="FILE" name="name" accept="time" value="text">

其中type属性是必须的。格式通过使用MIME码指定。常用的格式如下:


超文本标记语言文本 .html,.html text/html

  普通文本 :txt text/plain

  word文档:application/msword

  RTF文本 :rtf application/rtf

  GIF图形 :gif image/gif

  JPEG图形 :jpeg,

  jpg: image/jpeg

  au声音文件:au audio/basic

  MIDI音乐文件 :mid,.midi audio/midi,audio/x-midi

  RealAudio音乐文件 .ra, .ram audio/x-pn-realaudio

  MPEG文件 .mpg,.mpeg video/mpeg

  AVI文件 .avi video/x-msvideo

  GZIP文件 .gz application/x-gzip

  压缩文件.rar application/octet-stream

  压缩文件.zip application/x-zip-compressed

  TAR文件 .tar application/x-tar


更多提交表单的信息

  • 使用图像提交数据
<input type="image" src="url" name="text" align="align">
  • 创建重置按钮
<input type="reset" value="text">

见标签


1.段落标签<p>

  • <p>标签的默认样式,段前段后都会有空白,如果不喜欢这个空白,可以用css样式来删除或改变它。
  • 改变CSS样式删除段前段后空白处。
<style> 
 p{margin:0px;} 
</style>

2.斜体标签<em>

 <em>斜体</em>

3.粗体标签<strong>

 <strong>加粗</strong>

4.<span>标签

被用来组合文档中的行内元素。使用 <span> 来组合行内元素,以便通过样式来格式化它们。

  • <span> 在CSS定义中属于一个行内元素,在行内定义一个区域,也就是一行内可以被 <span>划分成好几个区域,从而实现某种特定效果。
  • <span>本身没有任何属性。
  • <div>在CSS定义中属于一个块级元素<div>可以包含段落、标题、表格甚至其它部分。这使DIV便于建立不同集成的类,如章节、摘要或备注。在页面效果上,使用<div> 会自动换行,使用<span> 就会保持同行。

例如:

 <style> 
 span{ color:blue; } 
 </style>

这样,<span>标签包含的文本就变成了蓝色的字体。

5.<q>标签

作用:段文本引用

例如:

<p>最初知道庄子,是从一首诗<q>庄生晓梦迷蝴蝶。望帝春心托杜鹃。</q>开始的。虽然当时不知道是什么意思,只是觉得诗句挺特别。后来才明白这个典故出自是庄子的《逍遥游》,《逍遥游》代表了庄子思想的最高境界,是对世俗社会的功名利禄及自己的舍弃。</p>
在上面的例子中,“庄生晓梦迷蝴蝶。望帝春心托杜鹃。” 这是一句诗歌,出自晚唐诗人李商隐的《锦瑟》 。因为不是作者自己的文字,所以需要使用<q></q>实现引用。
注意要引用的文本不用加双引号,浏览器会对q标签自动添加双引号。
这里用<q>标签的真正关键点不是它的默认样式双引号(如果这样我们不如自己在键盘上输入双引号就行了),而是它的语义:引用别人的话。
补充知识:语义化网页结构有助于搜索引擎的收录。同一个效果可以用很多钟方式实现,但这只方便了浏览者,而搜索引擎不知道这里到底是什么内容,这里如果你使用标签,那么就告诉浏览器这里是引用的话。而且在手持设备或移动设备不能很好支持css的基础上,浏览器会使用默认的效果,因而提供较好可读性。

6.<blockquote>标签

作用:长文本引用

例如:

<blockquote>明月出天山,苍茫云海间。长风几万里,吹度玉门关。汉下白登道,胡窥青海湾。由来征战地,不见有人还。 戍客望边色,思归多苦颜。高楼当此夜,叹息未应闲。</blockquote>

注意:浏览器对<blockquote>标签的解析是缩进样式

7.<br>标签

怎么可以让每一句诗词后面加入一个折行呢?那就可以用到<br />标签了,在需要加回车换行的地方加入<br />,<br />标签作用相当于word文档中的回车。

语法:

xhtml1.0写法:

 <br/>

html4.01写法:

 <br>

现在一般使用 xhtml1.0 的版本的写法(其它标签也是),这种版本比较规范。

与以前我们学过的标签不一样,<br />标签是一个空标签,没有HTML内容的标签就是空标签,空标签只需要写一个开始标签,这样的标签有<br />、<hr />和<img />。

讲到这里,你是不是有个疑问,想折行还不好说嘛,就像在 word 文件档或记事本中,在想要折行的前面输入回车不就行了吗? 不好意思,在 html 中是忽略回车和空格的,你输入的再多回车和空格也是显示不出来的。

8.<hr>标签

在信息展示时,有时会需要加一些用于分隔的横线,这样会使文章看起来整齐些。

语法:

html4.01版本

<hr>

xhtml1.0版本

<hr/>

注意:

  • <hr />标签和<br />标签一样也是一个空标签,所以只有一个开始标签,没有结束标签。
  • <hr />标签的在浏览器中的默认样式线条比较粗,颜色为灰色,可能有些人觉得这种样式不美观,没有关系,这些外在样式在我们以后学习了css样式表之后,都可以对其修改。
  • 大家注意,现在一般使用 xhtml1.0 的版本(其它标签也是),这种版本比较规范

9.<address>标签

一般网页中会有一些网站的联系地址信息需要在网页中展示出来,这些联系地址信息如公司的地址就可以<address>标签。也可以定义一个地址(比如电子邮件地址)、签名或者文档的作者身份。

语法:

 <address>联系地址信息</address>

如:

<address>文档编写:lilian 北京市西城区德外大街10号</address>

10.<code>标签

在介绍语言技术的网站中,避免不了在网页中显示一些计算机专业的编程代码,当代码为一行代码时,你就可以使用<code>标签了,如下面例子:

<code>var i=i+300;</code>

注意:在文章中一般如果要插入多行代码时不能使用<code>标签了。

语法:

<code>代码语言</code>

:如果是多行代码,可以使用<pre>标签。

11.<pre>标签

主要作用:预格式化的文本。被包围在 pre 元素中的文本通常会保留空格和换行符。

语法:

<pre>语言代码段</pre>

如下代码:

<pre> 
 var message="欢迎"; 
 for(var i=1;i<=10;i++) { 
 alert(message); 
 } 
</pre>

效果如下:

注意:<pre> 标签不只是为显示计算机的源代码时用的,在你需要在网页中预显示格式时都可以使用它,只是<pre>标签的一个常见应用就是用来展示计算机的源代码。

12.<ul>标签

ul-li是没有前后顺序的信息列表。

  • 这样是空心圆,
ul{ list-style:circle; }
  • 这个就是去除前面的点
ul{ list-style:none }
  • 语法:
<ul> 
 <li>信息</li> 
 <li>信息</li> 
 ...... 
</ul>
  • 举例:
<ul> 
 <li>精彩少年</li> 
 <li>美丽突然出现</li> 
 <li>触动心灵的旋律</li> 
</ul>
  • ul-li在网页中显示的默认样式一般为:每项li前都自带一个圆点

13.<ol>标签

ol-li是有前后顺序的信息列表

  • 语法:
<ol> 
 <li>信息</li> 
 <li>信息</li> 
 ...... 
</ol>
  • 举例:
 <ol> 
 <li>前端开发面试心法 </li> 
 <li>零基础学习html</li>
 <li>JavaScript全攻略</li> 
</ol>

<ol>在网页中显示的默认样式一般为:每项<li>前都自带一个序号,序号默认从1开始。

14.<div>标签

  • <div> 可定义文档中的分区或节(division/section)。
  • <div>标签可以把文档分割为独立的、不同的部分。它可以用作严格的组织工具,并且不使用任何格式与其关联。
  • 如果用 id 或 class 来标记 <div>,那么该标签的作用会变得更加有效。
  • <div>是一个块级元素。这意味着它的内容自动地开始一个新行。实际上,换行是 <div>固有的唯一格式表现。可以通过<div> 的 class 或 id 应用额外的样式。不必为每一个 <div> 都加上类或 id,虽然这样做也有一定的好处。
  • 可以对同一个 <div>元素应用 class 或 id 属性,但是更常见的情况是只应用其中一种。这两者的主要差异是,class 用于元素组(类似的元素,或者可以理解为某一类元素),而id 用于标识单独的唯一的元素。

15.<table>标签

  • 常用属性

1)属性:border

作用:规定表格边框的宽度

2)属性:cellpadding

作用:单元格中的文本与单元格边框的间距

3)属性:cellspacing

作用:单元格之间的间距

  • 创建表格的四个元素:

table、tbody、tr、th、td

1、<table>…</table>:整个表格以<table>标记开始、</table>标记结束。

2、<tbody>…</tbody>:当表格内容非常多时,表格会下载一点显示一点,但如果加上<tbody>标签后,这个表格就要等表格内容全部下载完才会显示。如右侧代码编辑器中的代码。

3、<tr>…</tr>:表格的一行,所以有几对tr 表格就有几行。

4、<td>…</td>:表格的一个单元格,一行中包含几对<td>...</td>,说明一行中就有几列。

- 常用属性: colspan:规定单元格可横跨的列数,值为数字 rowspan:规定单元格可横跨的行数,值为数字

5、<th>…</th>:表格的头部的一个单元格,表格表头。

6、表格中列的个数,取决于一行中数据单元格的个数。

总结:

  • 1、表头,也就是th标签中的文本默认为粗体并且居中显示
  • 2、table表格在没有添加css样式之前,在浏览器中显示是没有表格线的
  • 3、用css样式,为表格加入边框Table 表格在没有添加 css 样式之前,是没有边框的。

16.<caption>标签

表格还是需要添加一些标签进行优化,可以添加标题和摘要。

  • 摘要

摘要的内容是不会在浏览器中显示出来的。它的作用是增加表格的可读性(语义化),使搜索引擎更好的读懂表格内容,还可以使屏幕阅读器更好的帮助特殊用户读取表格内容。语法:

<table summary="表格简介文本">
  • 标题

用以描述表格内容,标题的显示位置:表格上方。语法:

<table> 
 <caption>标题文本</caption> 
 <tr> 
 <td>…</td> 
 <td>…</td> 
 … 
 </tr> 
 … 
</table>

17.<a>标签

  • _blank --在新窗口中打开链接
  • _parent --在父窗体中打开链接
  • _self --在当前窗体打开链接,此为默认值
  • _top --在当前窗体打开链接,并替换当前的整个窗体(框架页)
  • 一个对应的框架页的名称 -在对应框架页中打开
  • href:Hypertext Reference的缩写。意思是超文本引用。
  • 使用<a>标签可实现超链接,它在网页制作中可以说是无处不在,只要有链接的地方,就会有这个标签。语法:
 <a href="目标网址" title="鼠标滑过显示的文本">链接显示的文本</a>

例如:

 <a href="http://www.imooc.com" title="点击进入慕课网">click here!</a>

上面例子作用是单击click here!文字,网页链接跳转到http://www.imooc.com这个网页。

  • <a>标签在默认情况下,链接的网页是在当前浏览器窗口中打开,有时我们需要在新的浏览器窗口中打开。如下代码:
 <a href="目标网址" target="_blank">click here!</a>
  • title属性的作用,鼠标滑过链接文字时会显示这个属性的文本内容。这个属性在实际网页开发中作用很大,主要方便搜索引擎了解链接地址的内容(语义化更友好)。
  • 注意:还有一个有趣的现象不知道小伙伴们发现了没有,只要为文本加入a标签后,文字的颜色就会自动变为蓝色(被点击过的文本颜色为紫色),颜色很难看吧,不过没有关系后面我们学习了css样子就可以设置过来(a{color:#000}),下面会详细讲解。
  • 使用mailto在网页中链接Email地址

<a>标签还有一个作用是可以链接Email地址,使用mailto能让访问者便捷向网站管理者发送电子邮件。

注意:如果mailto后面同时有多个参数的话,第一个参数必须以“?”开头,后面的参数每一个都以“&”分隔。引号只有一对!

例子:
<a href="mailto:yy@qq.com? cc=xx@qq.com & bcc=aa@qq.com & subject=邮件主题 & body=邮件内容">
  • 如果:A 发送邮件给B1、B2、B3,抄送给C1、C2、C3,密送给D1、D2、D3。
那么:
1)A知道自己发送邮件给了B1、B2、B3,并且抄送给了C1、C2、C3,密送给了D1、D2、D3。
2)B1知道这封是A发送给B1、B2、B3的邮件,并且抄送给了C1、C2、C3,但不知道密送给了D1、D2、D3。
3)C1知道这封是A发送给B1、B2、B3的邮件,并且抄送给了C1、C2、C3,但不知道密送给了D1、D2、D3。
4)D1知道这封是A发送给B1、B2、B3的邮件,并且抄送给了C1、C2、C3,而且密送给了自己,但不知道密送给了D2、D3。
5)邮箱地址
 mailto: <a href="mailto:qiujie@staff.weibo.com">发送</a>
6)抄送地址
cc: <a href="mailto:qiujie@staff.weibo.com?cc=zz@sina.com">发送</a>
7)密件抄送地址
用分号分隔: <a href="mailto:qiujie@staff.weibo.com?bcc=zz@sina.com">发送</a>
8)多个收件人、抄送人、密送人 ;
bcc: <a href="mailto:qiujie@staff.weibo.com;zz@sina.com">发送</a>
9)邮件主题
subject: <a href="mailto:qiujie@staff.weibo.com?subject=邮件主题">发送</a>
10)邮件内容
body: <a href="mailto:qiujie@staff.weibo.com?body=邮件正文">发送</a>
例子:
<a href="mailto:yy@imooc.com;10001@qq.com?cc=10002@qq.com&bbc=madanteng@qqhelp.com&subject=观了不起的盖茨比有感。&body=你好,对此评论有些想法。">对此影评有何感想,发送邮件给我</a>

18.<img>标签

在网页的制作中为使网页炫丽美观,肯定是缺少不了图片,可以使用

标签来插入图片。

  • 语法:
 [站外图片上传中……(2)] <img src="myimage.gif" alt="My Image" title="My Image" />
  • 讲解:
src:标识图像的位置;
alt:指定图像的描述性文本,当图像不可见时(下载不成功时),可看到该属性指定的文本;
title:提供在图像可见时对图像的描述(鼠标滑过图片时显示的文本);
图像可以是GIF,PNG,JPEG格式的图像文件。
路径有两种填写方式:绝对路径、相对路径
相对路径:相对于我们当前 html 文件的位置来写路径即可!
./表示当前目录,../表示上一级目录

19.<form>标签

注意:

1、所有表单控件(文本框、文本域、按钮、单选框、复选框等)都必须放在<form></form>标签之间(否则用户输入的信息可提交不到服务器上哦!)。

2、method:post/get的区别这一部分内容属于后端程序员考虑的问题。

  • 网站怎样与用户进行交互?答案是使用HTML表单(form)。表单是可以把浏览者输入的数据传送到服务器端,这样服务器端程序就可以处理表单传过来的数据。

语法:

<form method="传送方式" action="服务器文件">
  • 讲解:
<form> :<form>标签是成对出现的,以<form>开始,以</form>结束。
action :浏览者输入的数据被传送到的地方,比如一个PHP页面(save.php)。
method : 数据传送的方式(get/post)。
 <form method="post" action="save.php"> 
 <label for="username">用户名:</label> 
 <input type="text" name="username" /> 
 <label for="pass">密码:</label> 
 <input type="password" name="pass" /> 
 </form>

20.<input>标签

  • 当用户要在表单中键入字母、数字等内容时,就会用到文本输入框。文本框也可以转化为密码输入框。

语法:

 <form> 
 <input type="text/password" name="名称" value="文本" /> 
 </form>
  • 属性:
举例:
 <form> 
 姓名: <input type="text" name="myName"/><br/> 
 密码: <input type="password" name="pass"/> 
 </form>
 value="xxx" 替换为 placeholder="xxx" 的体验更好一些,placeholder属性为 HTML 5 的新属性。placeholder 属性提供可描述输入字段预期值的提示信息(hint)。该提示会在输入字段为空时显示,并会在字段获得焦点时消失。

语法:

<input placeholder="text"/>
注释:placeholder 属性适用于以下的 <input> 类型:text, search, url, telephone, email 以及 password。

注意:同一组的单选按钮,name 取值一定要一致,比如上同一个名称“gender”,这样同一组的单选按钮才可以起到单选的作用!

type:

  • 当type="text"时,输入框为文本输入框;
  • 当type="password"时, 输入框为密码输入框。
  • hidden 定义隐藏输入字段
  • image 定义图像作为提交按钮
  • number 定义带有 spinner 控件的数字字段
  • password 定义密码字段。字段中的字符会被遮蔽
  • radio 定义单选按钮
  • checkbox 定义复选框按钮
  • range 定义带有 slider 控件的数字字段
  • reset 定义重置按钮。重置按钮会将所有表单字段重置为初始值
  • search 定义用于搜索的文本字段
  • submit 定义提交按钮。提交按钮向服务器发送数据
  • text 默认。定义单行输入字段,用户可在其中输入文本。默认是 20 个字符
  • url 定义用于 URL 的文本字段

name:为文本框命名,以备后台程序ASP 、PHP使用。

value:为文本输入框设置默认值。(一般起到提示作用)

21.<textarea>标签

  • 当用户需要在表单中输入大段文字时,需要用到文本输入域。

语法:

 <textarea rows="行数" cols="列数">文本</textarea>
  1. <textarea>标签是成对出现的,以<textarea>开始,以</textarea>结束。
  2. cols :多行输入域的列数。
  3. rows :多行输入域的行数。
  4. 在<textarea></textarea>标签之间可以输入默认值。

举例:

 <form method="post" action="save.php"> 
 <label>联系我们</label> 
 <textarea cols="50" rows="10" >在这里输入内容...</textarea> 
 </form>

22.<select>标签

  • 使用下拉列表框,节省空间。下拉列表在网页中也常会用到,它可以有效的节省网页空间。既可以单选、又可以多选。

语法:

 <select> 
 <option value="提交的值">显示的值</option> ... 
 </select>
 设置selected="selected"属性,则该选项就被默认选中。 
 selected="selected"
  • 若想实现多选
<select multiple="multiple"> 然后选择时候按ctrl点鼠标选中
  • 若想让某个选项不可选
<option disabled="disabled">
  • optgroup 标签

把相关的选项组合在一起

属性 label:给选项组命名

属性 disabled:禁用该选项组

23.<label>标签

  • label标签不会向用户呈现任何特殊效果,它的作用是为鼠标用户改进了可用性。如果你在 label 标签内点击文本,就会触发此控件。就是说,当用户单击选中该label标签时,浏览器就会自动将焦点转到和标签相关的表单控件上(就自动选中和该label标签相关连的表单控件上)。
  • 语法:
 <label for="控件id名称">

注意:标签的 for 属性中的值应当与相关控件的 id 属性值一定要相同。

  • 例子:
 <form> 
 <label for="male">男</label> 
 <input type="radio" name="gender" id="male" /> <br /> 
 <label for="female">女</label> 
 <input type="radio" name="gender" id="female" /> 
 <label for="email">输入你的邮箱地址</label> 
 <input type="email" id="email" placeholder="Enter email"> 
 </form>

24.<map>标签

使用 map 标签可以给图片某块区域加超链接

使用方法:

1)为 map 标签首先加上 id 属性用来为 map 标签定义一个唯一的名称

2)为了保证兼容性再加上 name 属性,属性值与 id 的值相同

3)为 map 标签所作用的图片加上 usemap 属性,属性值为 #id 名称

4)在 map 标签内嵌套 area 标签来实现给指定区域加链接

 <area shape="" coords="" href="" alt="" />
 shape 属性:定义链接区域的形状,常用值 rect、circle
 coords 属性:确定区域的精确位置。填写坐标即可,以父元素左上角为原点,可借助qq截图来得到想要的坐标
 href 属性:填写链接地址即可
 alt 属性:给链接加一些说明信息

例子:

 <map id="img1" name="img1"> 
 <area shape="rect" coords="184,33,391,258" href="http:www.baidu.com" alt="百度一下" target="_blank" /> 
 <area shape="circle" coords="507,287,20" href="http://www.sifangku.com" alt="私房库我的博客" target="_blank" /> 
 </map>

注意:

  1. 第一个coords的四个参数中,前两个参数为矩形的接近原点的顶角的坐标,后两个参数为对角的坐标。
  2. 第二个coords的三个参数中,前两个为圆心坐标,第三个参数为圆的半径。

25.<iframe>标签

创建包含另外一个文档的内联框架(即行内框架)

属性:

  • frameborder

值:1、0

作用:规定是否显示框架周围的边框。

  • width值:以像素计的宽度值、以包含元素百分比计的宽度值

作用:定义 iframe 的宽度

  • height

作用:定义高度

  • name

作用:给 iframe 命名

  • scrolling

值:yes、no、auto

作用:规定是否在 iframe 中显示滚动条

  • src

作用:规定在 iframe 中显示的文档的 URL

可以是本地的 html 文件,也可以是远程的 html 文件

标签写法与嵌套的讨论


标签写法

  • 元素标记的省略(在 html5 里面有的标记是可以省略不写的)

1)不允许写结束标签的元素

area,base,br,col,command,embed,hr,img,input,keygen,link,meta,paran,source,track,wbr。这些标签都是单标签例如:br 标签,不可以这样<br></br>,只能<br />这样来关闭标签。

2)可以省略结束标记的元素有:

 li,dt,dd,p,rt,rp,optgroup,option,colgroup,thead,tbody,tfoot,tr,td,th。

3)可以省略全部标记的元素有

 html,head,body,colgroup,tbody
  • 具有 boolean 值得属性
 例如:disabled,readonly,checked 等只写属性而不写属性值得时候当做 ture
 不写属性表示 false
  • 属性值的引号可以省略
 要求:属性值不包含 空字符串,<,>,=, ‘

标签嵌套探讨


1.html 规定我们必须要嵌套着写的标签

例如:页面头部是嵌套在 head 标签里面的,主体内容都是嵌套在 body 标签里面的表单的内容是嵌套在 form 标签里面的,dt、dd 是嵌套在 dl 标签里面的,li 是嵌套到ul 标签里面的,等等...

2.块级元素可以嵌套内联元素,但是内联元素不能包含块元素

<div>
 <span>我是一个 span 元素</span>
 </div> —— 对 
<span>
 <div>div 元素</div>
</span> —— 错

3.内联元素可以嵌套内联元素

<a href="#">
 <span></span>
</a> —— 对

4.块级元素与块级元素嵌套注意点

  • div 块级元素是一个容器,几乎可以存放任何常用标签,包括自己,我们为什么要使用 div 来嵌套标签?这个问题可以用用我们国家的省份划分来解释,国家需要划分不同的省份来利于管理,那么我们 html 页面也是的,整个 html 文档元素太多,我们需要使用 div 标签将页面划分成不同的块,这样可以对每块进行分开管理,学完 css 我们就知道怎么进行管理了。
  • 块级元素不能放在 p 标签里面
<p><ol><li></li></ol></p> —— 错 <p><div></div></p> —— 错
  • li 内可以包含 div 标签,li 和 div 标签都是装载内容的容器,地位平等,没有级别之分(例如:h1、h2 这样森严的等级制度) ,要知道 li 标签连它的父级 ul 或者是 ol 都可以容纳的

喜欢前端的小伙伴们可以在评论区留言,寻找和小冯童鞋一样热爱前端的友人,让我们一起玩转前端的世界!