没人愿意使用这些 HTML 标记
|
admin
2024年10月18日 22:44
本文热度 753
|
在前端开发中,HTML标签是构建网页结构的基础。然而,除了常用的<div>
、<a>
和<p>
等标签外,HTML还提供了许多鲜为人知但功能强大的标签。本文将介绍10个这样的标签,它们能为你的网页开发带来意想不到的便利和效果。
1.<progress>
和 <meter>
:进度条的两种形式
<progress>
标签用于创建标准的进度条:
<progress value="70" max="100"></progress>
data:image/s3,"s3://crabby-images/b5b66/b5b66f4c98b0029882aa7a2610bec6d5f5174570" alt=""
而<meter>
则提供了更丰富的显示选项:
data:image/s3,"s3://crabby-images/23b73/23b739696d17349c32cddfc7999a33f9530aa65b" alt=""
data:image/s3,"s3://crabby-images/5680e/5680e0e634f73825873b1be0fe45aee1f8dd4545" alt=""
2.<dfn>
:定义术语
用于标记页面中要定义的术语:
data:image/s3,"s3://crabby-images/919d9/919d9899457785da598c7f859c9a3471f1eb33f9" alt=""
data:image/s3,"s3://crabby-images/d6151/d61516707ee78fcb8a3a1f9367434fb26279a5c6" alt=""
3.<dialog>
:原生对话框
HTML5引入的原生对话框元素,支持简单的开关控制:
data:image/s3,"s3://crabby-images/24de1/24de1a191c293b339fa843dec08e94a39e270e09" alt=""
data:image/s3,"s3://crabby-images/b498e/b498e6254fdaa0fa7f4d4d119d63f9e7cbdc4915" alt=""
data:image/s3,"s3://crabby-images/62742/62742278f3dcabaffe840dc5d693f6eaf36db9e4" alt=""
4.<map>
和 <area>
:创建图像热区
这两个标签结合使用可以创建可点击的图像区域:
<img src="workplace.jpg" alt="Workplace" usemap="#workmap" width="400" height="379">
<map name="workmap">
<area shape="rect" coords="34,44,270,350" alt="Computer" href="computer.htm">
<area shape="rect" coords="290,172,333,250" alt="Phone" href="phone.htm">
</map>
我们把这样的可点击图像称为图像地图。
data:image/s3,"s3://crabby-images/e66fc/e66fc99dbb5fb18fdd503af571593e2f1aed45ff" alt=""
5.<bdo>
:文本方向控制
用于改变文本的显示方向:
data:image/s3,"s3://crabby-images/1eaed/1eaedb70d2e6cc05cfd9d9dcd82d38e3b0b48121" alt=""
data:image/s3,"s3://crabby-images/415c3/415c301b416268c58afe75c1be281b70394596ed" alt=""
6 <base>
:设置基础URL
你知道相对 URL 通常是如何工作的:
data:image/s3,"s3://crabby-images/3637d/3637d2887e80d829872ee53e6c74b78cc2a300bd" alt=""
<a>
会使用页面的域名来获取完整的URL
data:image/s3,"s3://crabby-images/d2ab0/d2ab058e51cb812d6850ccacd1c7eb81c62f0e63" alt=""
但是,如果在 HTML 中创建一个基础 <base>
会怎样呢
data:image/s3,"s3://crabby-images/61d5e/61d5eac3837405401c6698e5e8a342291952f491" alt=""
现在,它们都使用 <base>
的href中的硬编码值来获取完整的 URL:
data:image/s3,"s3://crabby-images/12d8d/12d8d0694f90e896143c33278110fea29467dbfc" alt=""
Angular 和 Flutter Web 等框架也在使用它
data:image/s3,"s3://crabby-images/c80a1/c80a17ac29bf1b21035bdb7350229f9d2bd18e17" alt=""
7.<time>
:标记日期和时间
有助于搜索引擎理解页面中的时间信息:
data:image/s3,"s3://crabby-images/1617c/1617c74d0f9b98068feeb5e97e8105faccbd2e71" alt=""
data:image/s3,"s3://crabby-images/d99d7/d99d76966436ac99f6afb718915409b303d175ee" alt=""
8.<hgroup>
:标题组
用于组合相关的标题元素:
data:image/s3,"s3://crabby-images/8f62e/8f62e7d5e933577372eaf1baf535ae2a0a8c70b3" alt=""
data:image/s3,"s3://crabby-images/d073a/d073a6fd760fa4c740e493e4e08bd154cfb9bc9a" alt=""
9.<kbd>
:表示键盘输入
用于显示键盘输入:
data:image/s3,"s3://crabby-images/2acd2/2acd24a2d317cfaae467618f158576714b3fb6dd" alt=""
data:image/s3,"s3://crabby-images/c7db3/c7db3edf5495fd12e30f1984748f323b66498814" alt=""
10. <cite>
用于标记创意作品的标题:
data:image/s3,"s3://crabby-images/6e325/6e3253c5d92fe83ed856574d10d14cce21faa09c" alt=""
结语
这些标签虽然使用频率不高,但在特定场景下能发挥重要作用。例如,<progress>
和<meter>
可以在数据可视化中使用,<dialog>
为创建模态框提供了原生支持,而<time>
则有助于提高网页的SEO友好度。
在实际开发中,合理使用这些标签不仅可以提高HTML的语义化程度,还能简化JavaScript代码。例如,使用<dialog>
代替自定义的模态框实现,可以减少大量的JavaScript代码:
<dialog id="myDialog">
<h2>重要通知</h2>
<p>这是一个原生对话框。</p>
<button id="closeDialog">关闭</button>
</dialog>
<script>
const dialog = document.getElementById('myDialog');
const closeButton = document.getElementById('closeDialog');
// 打开对话框
dialog.showModal();
// 关闭对话框
closeButton.addEventListener('click', () => {
dialog.close();
});
</script>
通过深入了解和灵活运用这些鲜为人知的HTML标签,开发者可以创建出更加语义化、易于维护且对搜索引擎友好的网页。在追求技术创新的同时,回归HTML基础,探索这些被忽视的标签,也许能为你的前端开发带来新的灵感和效率提升。
该文章在 2024/10/19 12:45:33 编辑过