ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
# 网页元素的属性 ## 简介 网页元素的属性(attribute)可以定制元素的行为,不同的属性会导致元素有不同的行为。元素属性的写法是 HTML 标签内部的“键值对”。 ```html <html lang="en"> ``` 上面代码中,`<html>`标签内部的键值对`lang="en"`,就称为`html`元素的属性。属性名为`lang`,属性值为`en`。 属性名与标签名一样,不区分大小写,`lang`和`LANG`是同一个属性。 属性名与属性值之间,通过等号`=`连接。属性值可以放在单引号或双引号之中,建议统一使用双引号。某些属性值可以不使用引号,但是建议不要这样写。 有些属性是布尔属性,即属性值是一个布尔值,只有“打开”和“关闭”两种情况。这时属性值可以省略,只要添加了属性名,就表示打开该属性。 ```html <input type="text" required> ``` 上面代码中,`required`就是`<input>`标签的布尔属性。如果加上这个属性,就表示打开,没有就是关闭。 ## 全局属性 全局属性(global attributes)是所有元素都可以使用的属性。也就是说,你可以把下面的属性,加在任意一个网页元素上面,不过有些属性对某些元素可能不产生意义。 下面是一些常见的全局属性。 ### id `id`属性是元素在网页内的唯一标识符。比如,网页可能包含多个`<p>`标签,`id`属性可以指定每个`<p>`标签的唯一标识符。 ```html <p id="p1"></p> <p id="p2"></p> <p id="p3"></p> ``` 上面代码中,三个`<p>`标签具有不同的`id`属性,因此可以区分。 `id`属性的值必须是全局唯一的,同一个页面不能有两个相同的`id`属性。另外,`id`属性的值不得包含空格。 `id`属性的值还可以在最前面加上`#`,放到 URL 中作为锚点,定位到该元素在网页内部的位置。比如,用户访问网址`https://foo.com/index.html#bar`的时候,浏览器会自动将页面滚动到`bar`的位置,让用户第一眼就看到这部分内容。 ### class `class`属性用来对网页元素进行分类。如果不同元素的`class`属性值相同,就表示它们是一类的。 ```html <p class="para"></p> <p></p> <p class="para"></p> ``` 上面代码中,第一个`<p>`和第三个`<p>`是一类,因为它们的`class`属性相同。 元素可以同时具有多个 class,它们之间使用空格分隔。 ```html <p class="p1 p2 p3"></p> ``` 上面的`p`元素同时具有`p1`、`p2`、`p3`三个 class。 ### title `title`属性用来为元素添加附加说明。大多数浏览器中,鼠标悬浮在元素上面时,会将`title`属性值作为浮动提示,显示出来。 ```html <div title="版权说明"> <p>本站内容使用创意共享许可证,可以自由使用。</p> </div> ``` 上面代码中,`title`属性解释了这一块内容的目的。鼠标悬停在上面时,浏览器会显示一个浮动提示。一旦鼠标移开,提示就会消失。 ### tabindex 网页通常使用鼠标操作,但是某些情况下,用户可能希望使用键盘,或者只有键盘可以用。因此,浏览器允许使用 Tab 键,遍历网页元素。也就是说,只要不停按下 Tab 键,网页的焦点就会从一个元素转移到另一个元素,选定焦点元素以后,就可以进行下一步操作,比如按下回车键访问某个链接,或者直接在某个输入框输入文字。 这里就有一个问题,按下 Tab 键的时候,浏览器怎么知道跳到哪一个元素。HTML 提供了`tabindex`属性,解决这个问题。它的名字的含义,就是 Tab 的顺序(index)。 `tabindex`属性的值是一个整数,表示用户按下 Tab 键的时候,网页焦点转移的顺序。不同的属性值有不同的含义。 - 负整数:该元素可以获得焦点(比如使用 JavaScript 的`focus()`方法),但不参与 Tab 键对网页元素的遍历。这个值通常是`-1`。 - `0`:该元素参与 Tab 键的遍历,顺序由浏览器指定,通常是按照其在网页里面出现的位置。 - 正整数:网页元素按照从小到大的顺序(1、2、3、……),参与 Tab 键的遍历。如果多个元素的`tabindex`属性相同,则按照在网页源码里面出现的顺序遍历。 ```html <p tabindex="0">这段文字可以获得焦点。</p> ``` 上面代码中,`<p>`标签的`tabindex`为`0`,意味着该元素可以获得焦点,并且也可以被 Tab 键遍历,顺序由其在源码里面的位置决定。 一般来说,`tabindex`属性最好都设成`0`,按照自然顺序进行遍历,这样比较符合用户的预期,除非网页有特殊布局。如果网页所有元素都没有设置`tabindex`,那么只有那些默认可以遍历的元素(比如链接、输入框等)才能参与 Tab 键的遍历,顺序由其在源码的位置决定。因此实际上,只有那些无法获得焦点的元素(比如`<span>`、`<div>`)需要参与遍历,才有必要设置`tabindex`属性。 ### accesskey `accesskey`属性指定网页元素获得焦点的快捷键,该属性的值必须是单个的可打印字符。只要按下快捷键,该元素就会得到焦点。 ```html <button accesskey="s">提交</button> ``` 上面代码中,`<button>`的快捷键是`s`,按下快捷键,该元素就得到了焦点。 `accesskey`属性的字符键,必须配合功能键,一起按下才会生效。也就是说,快捷键是“功能键 + 字符键”的组合。不同的浏览器与不同的操作系统,功能键都不一样。比如,Chrome 浏览器在 Windows 系统和 Linux 系统的快捷键是`Alt + 字符键`,在 Mac 系统的快捷键是`Ctrl + Alt + 字符键`。 注意,`accesskey`如果跟操作系统或浏览器级别的快捷键有冲突,这时不会生效。 ### style `style`属性用来指定当前元素的 CSS 样式。具体的设置,请看 CSS 教程。 ```html <p style="color: red;">hello</p> ``` 上面代码指定文字颜色为红色。 ### hidden `hidden`是一个布尔属性,表示当前的网页元素不再跟页面相关,因此浏览器不会渲染这个元素,所以就不会在网页中看到它。 ```html <p hidden>本句不会显示在页面上。</p> ``` 上面代码中,这个`p`元素不会出现在网页上。 注意,CSS 的可见性设置,高于`hidden`属性。如果 CSS 设为该元素可见,`hidden`属性将无效。 ### lang,dir `lang`属性指定网页元素使用的语言。 ```html <p lang="en">hello</p> <p lang="zh">你好</p> ``` 上面代码中,第一个`<p>`的`lang`属性,表示使用英语,第二个`<p>`的`lang`属性,表示使用中文。 `lang`属性的值,必须符合 [BCP47](https://www.ietf.org/rfc/bcp/bcp47.txt) 的标准。下面是一些常见的语言代码。 - zh:中文 - zh-Hans:简体中文 - zh-Hant:繁体中文 - en:英语 - en-US:美国英语 - en-GB:英国英语 - es:西班牙语 - fr:法语 `dir`属性表示文字的阅读方向,有三个可能的值。 - `ltr`:从左到右阅读,比如英语。 - `rtl`:从右到左阅读,阿拉伯语、波斯语、希伯来语都属于这一类。 - `auto`:浏览器根据内容的解析结果,自行决定。 ### contenteditable HTML 网页的内容默认是用户不能编辑,`contenteditable`属性允许用户修改内容。它有两个可能的值。 - `true`或空字符串:内容可以编辑 - `false`:不可以编辑 ```html <p contenteditable="true"> 鼠标点击,本句内容可修改。 </p> ``` 上面代码中,鼠标单击句子,就可以进入编辑状态,用户可以改变句子的内容。当然,除非提交到服务器,否则刷新页面还是显示原来的内容。 该属性是枚举属性,不是布尔属性,规范的写法是最好带上属性值。 ### spellcheck 浏览器一般会自带拼写检查功能,编辑内容时,拼错的单词下面会显示红色的波浪线。`spellcheck`属性就表示,是否打开拼写检查。 它有两个可能的值。 - `true`:打开拼写检查 - `false`:关闭拼写检查 ```html <p contenteditable="true" spellcheck="true"> 英语单词 separate 容易写错成 seperate。 </p> ``` 上面代码中,`seperate`下面会有提示,表示拼错了。 注意,由于该属性只在编辑时生效,所以这个例子必须加上`contenteditable`属性,表示本段内容可编辑。鼠标单击就可以进入编辑状态,这时才会看到拼写提示。不可编辑的状态下,拼写错误是不提示显示的。对于那些不可编辑的元素,该属性无效。 这个属性看上去像布尔属性,但是其实是枚举属性,所以最好不要省略它的值。如果没有指定这个属性,浏览器将自行决定是否打开拼写检查。 ### `data-`属性 `data-`属性用于放置自定义数据。如果没有其他属性或元素合适放置数据,就可以放在`data-`属性。 ```html <a href="#" class="tooltip" data-tip="this is the tip!">链接</a> ``` 上面代码中,`data-tip`用于放置链接的提示文字。 由于`data-`属性只能通过 CSS 或 JavaScript 利用,所以这里不做详细介绍了。下面是 CSS 的例子。 ```css /* HTML 代码如下 <div data-role="mobile"> Mobile only content </div> */ div[data-role="mobile"] { display:none; } /* HTML 代码如下 <div class="test" data-content="This is the div content">test</div>​ */ .test { display: inline-block; } .test:after { content: attr(data-content); } ``` ### 事件处理属性 除了上面这些属性,全局属性还包括事件处理属性(event handler),用来响应用户的动作。这些属性的值都是 JavaScript 代码,请参考 JavaScript 教程,这里只列出这些属性的名单。 > onabort, onautocomplete, onautocompleteerror, onblur, oncancel, oncanplay, oncanplaythrough, onchange, onclick, onclose, oncontextmenu, oncuechange, ondblclick, ondrag, ondragend, ondragenter, ondragexit, ondragleave, ondragover, ondragstart, ondrop, ondurationchange, onemptied, onended, onerror, onfocus, oninput, oninvalid, onkeydown, onkeypress, onkeyup, onload, onloadeddata, onloadedmetadata, onloadstart, onmousedown, onmouseenter, onmouseleave, onmousemove, onmouseout, onmouseover, onmouseup, onmousewheel, onpause, onplay, onplaying, onprogress, onratechange, onreset, onresize, onscroll, onseeked, onseeking, onselect, onshow, onsort, onstalled, onsubmit, onsuspend, ontimeupdate, ontoggle, onvolumechange, onwaiting