
DOCTYPE 和字符编码怎么写才不进怪异模式
HTML5 的 不是“简写”,而是一条强制浏览器启用标准模式的开关。写错一个字母、多一个空格,或混用 HTML4 的 DTD(比如 <code>..>),IE8–IE11 就可能直接切到怪异模式——盒模型变回 border-box、width 行为反直觉、float 布局错位,调试时容易误判成 CSS bug。
字符编码也一样:<meta charset="utf-8"> 必须放在 最前面(最好第二行),且不能和旧式写法 <meta http-equiv="content-type" content="text/html; charset=utf-8"> 并存。两者混用,部分浏览器会忽略后者,导致乱码;若 <meta charset> 被 JS 动态插入,也无效——它必须是 HTML 解析早期就存在的静态声明。
语义标签不是 div 换个名字,用错反而伤可访问性
<header></header>、<nav></nav>、<main></main>、<section></section>、<article></article> 这些标签默认无样式,也不提供额外布局能力。它们的核心价值在 DOM 结构层:屏幕阅读器靠它跳转区域,SEO 爬虫靠它识别内容权重,开发者靠它快速理解模块意图。
-
<main></main>全页只能出现一次,W3C 明确禁止嵌套或重复;多写了,辅助技术可能只读第一个 -
<section></section>必须有标题(<h1></h1>–<h6></h6>),否则语义断裂;它表示逻辑分组,不是视觉容器 -
<article></article>是可独立分发的内容单元(如一篇博客、一条新闻),能被 RSS 抓取;<section></section>则不能 - IE8 及更早版本完全不认识这些标签,连
document.querySelector("header")都返回null;必须引入html5shiv.js或手动document.createElement("header")
表单验证别全靠 required 和 pattern,移动端和 Safari 有坑
HTML5 表单属性确实省事:required 触发必填提示,type="email" 在 iOS 弹出邮箱键盘,pattern 支持正则校验——但它们不是万能的,尤其在兼容性和交互反馈上。
立即学习“前端免费学习笔记(深入)”;
-
<input type="date">在 Safari(包括 macOS 和 iOS)长期不支持原生日期选择器,用户看到的只是普通文本框;必须搭配 JS fallback(如 flatpickr) -
pattern的正则不支持 Unicode 属性类(如\p{Han}),也不能写全局标志/g;浏览器只校验输入值是否匹配整个字符串,不自动加^$ -
placeholder不是<label></label>替代品,它没语义、不被屏幕阅读器朗读、输入后消失;缺少<label for="xxx"></label>会导致无障碍失败 - 所有原生验证只在提交时触发(或调用
form.reportValidity()),blur/change 事件里不会自动校验;想实时反馈,仍得手写 JS
HTML4 标签和属性在 HTML5 里还能用吗
大部分能“渲染”,但很多已被标记为 obsolete(废弃),意味着:不推荐、不保证未来支持、可能被移除。这不是语法错误,而是设计淘汰。
-
<font></font>、<center></center>、<u></u>(非语义下划线)、align属性(如<div align="right">)已废弃;CSS 才是正确归宿 <li> <code><frame>、<frameset></frameset>、<noframes></noframes>彻底移除,现代浏览器已不解析 -
<img alt="HTML5不同版本差异大吗_HTML5与HTML4核心语法功能区别汇总【详解】" >的border、vspace、hspace属性失效;必须用 CSS 控制 - 即使用了废弃标签,HTML5 解析器也不会报错,但 W3C 验证器会标红;更重要的是,它们破坏语义结构,让机器(爬虫、阅读器)无法准确理解页面意图
HTML5 不是“新语言”,而是对 HTML 的一次语义重构和能力补全。差异不在语法复杂度,而在你组织结构、表达意图、处理兼容性的思路是否更新了——老写法能跑,不代表它还合理。











