登录
首页 >  文章 >  前端

HTML架构标准与文档规范解析要点

时间:2026-05-22 11:03:24 280浏览 收藏

本文深入剖析HTML作为语义化标记语言的本质定位——它不定义系统架构,而专注内容结构与可访问性;从DOCTYPE声明如何决定浏览器解析模式、head与body不可妥协的逻辑分区,到标签嵌套错误对语义和渲染的隐蔽破坏,再到class/id在DOM操控中的关键作用,揭示了那些看似琐碎却直接影响SEO、无障碍体验、JavaScript稳定性与团队协作质量的核心规范细节,提醒开发者:真正的工程严谨性,往往藏在“不报错却已失效”的边界之中。

HTML是什么架构标准 HTML文档规范解析【要点】

HTML 不是“架构标准”,而是定义网页内容结构与语义的标记语言规范。 它不规定系统级架构、模块通信或服务分层,只管“这段文字是不是标题”“这个区域是不是导航栏”“这张图缺了替代文本会怎样”。混淆这点,容易在工程设计中把语义结构和应用架构混为一谈。

DOCTYPE 声明决定浏览器用哪种规则解析 HTML

没有 ,或写错(比如漏空格、大小写混乱、多加斜杠),浏览器可能进入怪异模式(Quirks Mode)。这时 CSS 盒模型、getBoundingClientRect() 行为、甚至 document.body 的尺寸计算都可能和预期不一致。

  • 是唯一推荐写法,大小写不敏感但必须全小写以保团队统一
  • 旧式声明如 已无必要,也不再被现代工具链支持
  • 它不触发任何网络请求,也不影响 DOM 构建速度,但缺失会导致整个渲染流程降级

head 和 body 是强制存在的逻辑分区,不是可选容器

必须出现在 内且在 之前; 不能为空——哪怕只放一个

或注释也算合法。W3C 验证器会直接报错 Element “body” not allowed as child of element “html” in this context 如果顺序错乱或缺失。

  • 必须是 中第一个标签(或紧随 </code> 后),否则中文可能乱码</li> <li><code><title></code> 是 <code><head></code> 的直系子元素,不可嵌套在 <code><div></code> 或其他标签里</li> <li>外部 CSS 应放在 <code><head></code>,JS 脚本建议放在 <code></body></code> 前——这不是“最佳实践”的客气话,而是避免阻塞 DOM 解析的实际需要</li> </ul><h3>标签嵌套错误会静默破坏语义,但不一定报错</h3> <p>浏览器会自动修复很多嵌套错误(比如把 <code><p><div>xxx</div></p></code> 拆成 <code><p></p><div>xxx</div><p></p></code>),但修复结果不可控。屏幕阅读器、SEO 抓取、CSS 选择器作用域都会因此偏移。</p> <ul><li>块级元素(如 <code><div></code>、<code><p></code>)不能直接放在 <code><p></code> 内部</li> <li><code><li></code> 必须是 <code><ul></code> 或 <code><ol></code> 的直接子元素,中间插个 <code><span></code> 就会让列表语义断裂</li> <li>自闭合标签如 <code><img></code>、<code><input></code> 后面不加 <code>/></code> 完全合法(HTML5),但加了也不会错;而 <code><br></code> 写成 <code><br></br></code> 反而会被当成两个换行</li> </ul><h3>class 和 id 不是装饰用的,它们是 DOM 控制点</h3> <p>很多人把 <code>class</code> 当作纯 CSS 钩子,其实它是 JavaScript 操作节点最常用、最稳定的依据。一旦为了“好看”随意改 class 名,JS 功能就可能失效;id 更要小心——同一页面重复 id 不会报错,但 <code>document.getElementById()</code> 只返回第一个匹配项,<code>label[for]</code> 关联也会断掉。</p> <ul><li><code>class</code> 值应语义化(如 <code>js-modal-close</code>、<code>u-hidden-visually</code>),而非描述样式(如 <code>red-text</code>)</li> <li>id 必须全局唯一,且不能以数字开头(<code>id="1nav"</code> 是非法的,<code>id="nav-1"</code> 才合法)</li> <li>属性值一律用双引号包裹:<code>class="btn btn-primary"</code>,单引号或不加引号在某些解析器里会出问题</li> </ul><p>真正难的不是记住这些规则,而是当多人协作、模板引擎介入、SSR 渲染、微前端加载时,这些边界条件会被层层掩盖。一个没闭合的 <code><header></code> 可能让整个后续 DOM 树的层级错位,而控制台却不会报错。</p><p>到这里,我们也就讲完了《HTML架构标准与文档规范解析要点》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!</p> <div id="third-party-overlay" style="position:fixed;left:0;top:0;width:100%;height:100%;display:none;justify-content:center;align-items:center;background:rgba(0,0,0,0.4);z-index:9999;"> <div style="background:#FFF3CD;border:1px solid #FFEEBA;padding:16px;border-radius:6px;box-sizing:border-box;max-width:480px;width:90%;text-align:center;"> <div style="font-size:14px;color:#856404;margin-bottom:12px;">您即将跳转至第三方网站,请注意保护好个人信息和财产安全!</div> <a href="https://comicdow.pdlcomic.top/1273%2F%E5%9B%A7%E6%AC%A1%E5%85%83.apk" target="_blank" rel="nofollow noopener noreferrer" style="color:#2d8cf0;text-decoration:none;" onclick="showThirdParty('none');">继续访问</a> </div> </div> <script> function showThirdParty(mode){ var el = document.getElementById('third-party-overlay'); if (!el) return; el.style.display = (mode === 'none' ? 'none' : 'flex'); } </script> </div> <div class="labsList"> </div> </div> <div class="contBoxNor"> <div class="contTit"> <div class="tit">资料下载</div> </div> <ul class="classRecomList"> <li> <a href="https://pan.quark.cn/s/ba8ef670cabd" rel="nofollow" target="_blank" title="编程学习资料下载" class="img_box"> <img loading="lazy" src="/assets/images/xuexiziliao.jpeg" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="编程学习资料下载"> </a> <dl> <dt class="lineOverflow"> <a href="https://pan.quark.cn/s/ba8ef670cabd" rel="nofollow" target="_blank" class="aBlack" title="编程学习资料下载">编程学习资料下载</a> </dt> <dd class="cont1 lineTwoOverflow"> 精选 编程(Golang、Python、Java、C++、JavaScript等) 教程、电子书与示例源码,一键打包本地下载学习。 </dd> <dd class="cont2"> <a href="https://pan.quark.cn/s/ba8ef670cabd" rel="nofollow" target="_blank" class="toStudy">立即下载</a> </dd> </dl> </li> </ul> </div> <!-- 最新阅读 --> <div class="contBoxNor"> <div class="contTit"> <div class="tit">相关阅读</div> <a href="/articlelist.html" class="more">更多></a> </div> <ul class="latestReadList"> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  1年前  |   <a href="javascript:;" class="aLightGray" title="提升">提升</a> <a href="javascript:;" class="aLightGray" title="箭头函数">箭头函数</a> <a href="javascript:;" class="aLightGray" title="函数表达式">函数表达式</a> <a href="javascript:;" class="aLightGray" title="函数声明">函数声明</a> <a href="javascript:;" class="aLightGray" title="Function构造函数">Function构造函数</a> </div> <div class="tit lineOverflow"><a href="/article/207000.html" title="JavaScript函数定义及示例详解" class="aBlack">JavaScript函数定义及示例详解</a></div> <div class="opt"> <span><i class="view"></i>502</span> <span class="collectBtn user_collection" data-id="207000" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  2年前  |   <a href="javascript:;" class="aLightGray" title="CSS">CSS</a> <a href="javascript:;" class="aLightGray" title="优化">优化</a> <a href="javascript:;" class="aLightGray" title="体验">体验</a> </div> <div class="tit lineOverflow"><a href="/article/72840.html" title="优化用户界面体验的秘密武器:CSS开发项目经验大揭秘" class="aBlack">优化用户界面体验的秘密武器:CSS开发项目经验大揭秘</a></div> <div class="opt"> <span><i class="view"></i>501</span> <span class="collectBtn user_collection" data-id="72840" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  2年前  |   <a href="javascript:;" class="aLightGray" title="图片轮播">图片轮播</a> <a href="javascript:;" class="aLightGray" title="微信小程序">微信小程序</a> <a href="javascript:;" class="aLightGray" title="特效">特效</a> </div> <div class="tit lineOverflow"><a href="/article/76259.html" title="使用微信小程序实现图片轮播特效" class="aBlack">使用微信小程序实现图片轮播特效</a></div> <div class="opt"> <span><i class="view"></i>501</span> <span class="collectBtn user_collection" data-id="76259" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  2年前  |   <a href="javascript:;" class="aLightGray" title="sessionStorage">sessionStorage</a> <a href="javascript:;" class="aLightGray" title="存储能力">存储能力</a> <a href="javascript:;" class="aLightGray" title="限制解析">限制解析</a> </div> <div class="tit lineOverflow"><a href="/article/83771.html" title="解析sessionStorage的存储能力与限制" class="aBlack">解析sessionStorage的存储能力与限制</a></div> <div class="opt"> <span><i class="view"></i>501</span> <span class="collectBtn user_collection" data-id="83771" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  2年前  |   <a href="javascript:;" class="aLightGray" title="团队合作">团队合作</a> <a href="javascript:;" class="aLightGray" title="冒泡事件">冒泡事件</a> <a href="javascript:;" class="aLightGray" title="促进作用">促进作用</a> </div> <div class="tit lineOverflow"><a href="/article/85057.html" title="探索冒泡活动对于团队合作的推动力" class="aBlack">探索冒泡活动对于团队合作的推动力</a></div> <div class="opt"> <span><i class="view"></i>501</span> <span class="collectBtn user_collection" data-id="85057" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> </ul> </div> <!-- 最新阅读 --> <div class="contBoxNor"> <div class="contTit"> <div class="tit">最新阅读</div> <a href="/articlelist.html" class="more">更多></a> </div> <ul class="latestReadList"> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  2分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607364.html" title="HTML5视频苹果端位置下沉修复方法" class="aBlack">HTML5视频苹果端位置下沉修复方法</a></div> <div class="opt"> <span><i class="view"></i>393</span> <span class="collectBtn user_collection" data-id="607364" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  3分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607361.html" title="HTML script 标签的 crossorigin 属性用于控制脚本资源的跨域请求行为,尤其是在加载第三方脚本时。如果使用不当,可能会导致获取脚本报错,影响页面功能。一、crossorigin 属性简介crossorigin 是 <script> 标签的一个可选属性,用于指定在加载外部脚本(来自其他域)时,浏览器如何处理跨域请求。它有以下几种取值:anonymous:默认值,表示浏览器在发送请" class="aBlack">HTML script 标签的 crossorigin 属性用于控制脚本资源的跨域请求行为,尤其是在加载第三方脚本时。如果使用不当,可能会导致获取脚本报错,影响页面功能。一、crossorigin 属性简介crossorigin 是 <script> 标签的一个可选属性,用于指定在加载外部脚本(来自其他域)时,浏览器如何处理跨域请求。它有以下几种取值:anonymous:默认值,表示浏览器在发送请</a></div> <div class="opt"> <span><i class="view"></i>258</span> <span class="collectBtn user_collection" data-id="607361" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  8分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607356.html" title="Sass实现CSS变量注入与逻辑优化" class="aBlack">Sass实现CSS变量注入与逻辑优化</a></div> <div class="opt"> <span><i class="view"></i>356</span> <span class="collectBtn user_collection" data-id="607356" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  9分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607353.html" title="推荐好用的HTML编辑器【手册】" class="aBlack">推荐好用的HTML编辑器【手册】</a></div> <div class="opt"> <span><i class="view"></i>434</span> <span class="collectBtn user_collection" data-id="607353" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  11分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607351.html" title="Symbol.species 用于控制子类在方法调用后返回的实例类型,确保子类在继承时保持类型一致性。以下是实现步骤:定义父类:在父类中定义 Symbol.species 属性,指定子类应使用的构造函数。子类覆盖:子类可以覆盖 Symbol.species,以指定自己的构造函数。方法调用:当调用父类方法(如 map、filter)时,会使用 Symbol.species 指定的构造函数创建新实例。" class="aBlack">Symbol.species 用于控制子类在方法调用后返回的实例类型,确保子类在继承时保持类型一致性。以下是实现步骤:定义父类:在父类中定义 Symbol.species 属性,指定子类应使用的构造函数。子类覆盖:子类可以覆盖 Symbol.species,以指定自己的构造函数。方法调用:当调用父类方法(如 map、filter)时,会使用 Symbol.species 指定的构造函数创建新实例。</a></div> <div class="opt"> <span><i class="view"></i>467</span> <span class="collectBtn user_collection" data-id="607351" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  12分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607350.html" title="如何用监控工具测 querySelector 耗时" class="aBlack">如何用监控工具测 querySelector 耗时</a></div> <div class="opt"> <span><i class="view"></i>261</span> <span class="collectBtn user_collection" data-id="607350" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  14分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607348.html" title="HTML性能优化技巧汇总" class="aBlack">HTML性能优化技巧汇总</a></div> <div class="opt"> <span><i class="view"></i>229</span> <span class="collectBtn user_collection" data-id="607348" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  15分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607346.html" title="HTML中使用insertAdjacentHTML插入HTML字符串的方法" class="aBlack">HTML中使用insertAdjacentHTML插入HTML字符串的方法</a></div> <div class="opt"> <span><i class="view"></i>398</span> <span class="collectBtn user_collection" data-id="607346" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  17分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607345.html" title="在文本中插入小型引用 _CITE 标签标注作品标题,通常用于学术写作、文章引用或内容创作中,以标明引用来源。以下是几种常见方式:1. 直接插入标签(适用于网页或Markdown格式)这是一段文字,引用了 _CITE[作品标题]_。效果: 这是一段文字,引用了 [作品标题]。2. 带作者信息的引用(可选)这是一段文字,引用了 _CITE[作品标题, 作者名]_。效果: 这是一段文字,引用了 [作品标" class="aBlack">在文本中插入小型引用 _CITE 标签标注作品标题,通常用于学术写作、文章引用或内容创作中,以标明引用来源。以下是几种常见方式:1. 直接插入标签(适用于网页或Markdown格式)这是一段文字,引用了 _CITE[作品标题]_。效果: 这是一段文字,引用了 [作品标题]。2. 带作者信息的引用(可选)这是一段文字,引用了 _CITE[作品标题, 作者名]_。效果: 这是一段文字,引用了 [作品标</a></div> <div class="opt"> <span><i class="view"></i>236</span> <span class="collectBtn user_collection" data-id="607345" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  22分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607336.html" title="CSS弹性拉伸:left和right设为0时自动填满" class="aBlack">CSS弹性拉伸:left和right设为0时自动填满</a></div> <div class="opt"> <span><i class="view"></i>338</span> <span class="collectBtn user_collection" data-id="607336" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  24分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607335.html" title="Bootstrap折叠失效原因:CSS过渡与Display冲突排查" class="aBlack">Bootstrap折叠失效原因:CSS过渡与Display冲突排查</a></div> <div class="opt"> <span><i class="view"></i>113</span> <span class="collectBtn user_collection" data-id="607335" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> <li> <div class="info"> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  27分钟前  |   </div> <div class="tit lineOverflow"><a href="/article/607331.html" title="CSS模态框居中技巧与定位方法" class="aBlack">CSS模态框居中技巧与定位方法</a></div> <div class="opt"> <span><i class="view"></i>119</span> <span class="collectBtn user_collection" data-id="607331" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </div> </li> </ul> </div> <!-- 课程推荐 --> <div class="contBoxNor"> <div class="contTit"> <div class="tit">课程推荐</div> <a href="/courselist.html" class="more">更多></a> </div> <ul class="classRecomList"> <li> <a href="/course/9.html" title="前端进阶之JavaScript设计模式" class="img_box"> <img loading="lazy" src="/uploads/20221222/52fd0f23a454c71029c2c72d206ed815.jpg" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="前端进阶之JavaScript设计模式"> </a> <dl> <dt class="lineOverflow"> 前端进阶之JavaScript设计模式 </dt> <dd class="cont1 lineOverflow">设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。</dd> <dd class="cont2"> <a href="/course/9.html" title="前端进阶之JavaScript设计模式" class="toStudy">立即学习</a> <span>543次学习</span> </dd> </dl> </li> <li> <a href="/course/2.html" title="GO语言核心编程课程" class="img_box"> <img loading="lazy" src="/uploads/20221221/634ad7404159bfefc6a54a564d437b5f.png" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="GO语言核心编程课程"> </a> <dl> <dt class="lineOverflow"> GO语言核心编程课程 </dt> <dd class="cont1 lineOverflow">本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。</dd> <dd class="cont2"> <a href="/course/2.html" title="GO语言核心编程课程" class="toStudy">立即学习</a> <span>516次学习</span> </dd> </dl> </li> <li> <a href="/course/74.html" title="简单聊聊mysql8与网络通信" class="img_box"> <img loading="lazy" src="/uploads/20240103/bad35fe14edbd214bee16f88343ac57c.png" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="简单聊聊mysql8与网络通信"> </a> <dl> <dt class="lineOverflow"> 简单聊聊mysql8与网络通信 </dt> <dd class="cont1 lineOverflow">如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让</dd> <dd class="cont2"> <a href="/course/74.html" title="简单聊聊mysql8与网络通信" class="toStudy">立即学习</a> <span>500次学习</span> </dd> </dl> </li> <li> <a href="/course/57.html" title="JavaScript正则表达式基础与实战" class="img_box"> <img loading="lazy" src="/uploads/20221226/bbe4083bb3cb0dd135fb02c31c3785fb.jpg" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="JavaScript正则表达式基础与实战"> </a> <dl> <dt class="lineOverflow"> JavaScript正则表达式基础与实战 </dt> <dd class="cont1 lineOverflow">在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。</dd> <dd class="cont2"> <a href="/course/57.html" title="JavaScript正则表达式基础与实战" class="toStudy">立即学习</a> <span>487次学习</span> </dd> </dl> </li> <li> <a href="/course/28.html" title="从零制作响应式网站—Grid布局" class="img_box"> <img loading="lazy" src="/uploads/20221223/ac110f88206daeab6c0cf38ebf5fe9ed.jpg" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="从零制作响应式网站—Grid布局"> </a> <dl> <dt class="lineOverflow"> 从零制作响应式网站—Grid布局 </dt> <dd class="cont1 lineOverflow">本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。</dd> <dd class="cont2"> <a href="/course/28.html" title="从零制作响应式网站—Grid布局" class="toStudy">立即学习</a> <span>485次学习</span> </dd> </dl> </li> </ul> </div> </div> <!-- footer --> <link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet"> <div class="footer"> <ul> <li ><a href="/" class="aLightGray"><em class="material-icons">home</em><span>首页</span></a></li> <li class="curr"><a href="/articlelist.html" class="aLightGray"><em class="material-icons">menu_book</em><span>阅读</span></a></li> <li ><a href="/courselist.html" class="aLightGray"><em class="material-icons">school</em><span>课程</span></a></li> <li ><a href="/ai.html" class="aLightGray"><em class="material-icons">smart_toy</em><span>AI助手</span></a></li> <li ><a href="/user.html" class="aLightGray"><em class="material-icons">person</em><span>我的</span></a></li> </ul> </div> <script src="/assets/js/require.js" data-main="/assets/js/require-frontend.js?v=1671101972"></script> <script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?3dc5666f6478c7bf39cd5c91e597423d"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script> <script src="/assets/js/SyntaxHighlighter/shCore.js?3.1.1"></script> <script> document.addEventListener('DOMContentLoaded', function () { if (document.querySelector('.cont pre')) { SyntaxHighlighter.all(); } }); </script> </body> </html>