当前位置:首页 > 文章列表 > 文章 > 前端 > HTML编写规范包括结构清晰、语义明确、代码简洁和易于维护。常见规范有:标签闭合、大小写统一、合理缩进、使用语义化标签、添加注释、属性有序排列、避免内联样式、声明文档类型。如何修改HTML文件?打开文件:用文本编辑器或IDE打开.html文件。编辑内容:修改标签内容,如标题。

HTML编写规范包括结构清晰、语义明确、代码简洁和易于维护。常见规范有:标签闭合、大小写统一、合理缩进、使用语义化标签、添加注释、属性有序排列、避免内联样式、声明文档类型。如何修改HTML文件?打开文件:用文本编辑器或IDE打开.html文件。编辑内容:修改标签内容,如标题。

2025-08-03 17:11:51 0浏览 收藏

HTML编写规范至关重要,它关乎代码的清晰度、可维护性及SEO优化。核心在于**结构清晰、语义明确、代码简洁和可维护性强**。语义化标签如`

`、`

编写HTML文档最重要的规范是语义化,使用header、nav、main等语义标签能提升可访问性、SEO和可维护性;2. 必须闭合标签并正确嵌套,避免结构混乱导致页面错误;3. 图片必须添加alt属性,表单元素需与label通过for和id关联,以保障可访问性;4. 保持代码可读性,统一缩进、添加必要注释,便于团队协作;5. 声明UTF-8字符编码和viewport元标签,确保页面正常显示和响应式适配;6. 修改HTML文件可用任何文本编辑器,推荐VS Code,结合开发者工具实时调试;7. 高效修改需善用浏览器开发者工具、Git版本控制、Emmet语法、代码格式化工具;8. 注意浏览器缓存和资源路径问题,利用控制台和网络面板排查加载错误;9. HTML5新特性包括audio和video多媒体标签,简化音视频嵌入;10. 新增表单类型如email、date、number及placeholder、required等属性,提升验证和用户体验;11. localStorage和sessionStorage提供客户端数据存储,支持离线应用;12. Canvas和SVG实现动态绘图与矢量图形展示,增强视觉表现;13. data-*属性允许在HTML中存储自定义数据,便于JavaScript访问,提升结构清晰度。遵循这些规范和技巧能显著提升HTML代码质量、开发效率和项目可维护性。

HTML文档的编写规范是什么?如何修改HTML文件?

HTML文档的编写规范,说白了就是一套让你的代码更易读、更健壮、更利于协作的“潜规则”。它关乎结构、语义、可访问性,以及长期的可维护性。而修改HTML文件,本质上就是用任何文本编辑器打开它,找到你需要调整的地方,然后保存,最后在浏览器里刷新看看效果。这听起来简单,但里面门道不少。

HTML文档的编写规范是什么?如何修改HTML文件?

解决方案

编写HTML文档,我个人觉得最重要的就是语义化。这不仅仅是为了让代码好看,更是为了让浏览器、搜索引擎和辅助技术(比如屏幕阅读器)能更好地理解你的页面结构和内容。别动不动就div走天下,能用headernavmainarticlesectionasidefooter这些标签的时候,就别吝啬。它们各自代表了不同的内容区域,用对了,页面的骨架就清晰了。

除了语义化,还有几点是写HTML时得刻在脑子里的:

HTML文档的编写规范是什么?如何修改HTML文件?
  • 闭合标签和正确嵌套: 这是一个基本功,但有时候忙起来,或者代码量大了,就容易漏掉。不闭合或者嵌套混乱,轻则样式错乱,重则页面直接崩掉。
  • 属性规范: 比如图片一定要有alt属性,它不仅仅是为了SEO,更是为了那些看不到图片的用户。表单元素和对应的label标签要用forid关联起来,这直接影响到可访问性。
  • 代码可读性: 统一的缩进(我个人偏爱2个空格,但4个也行,关键是统一)、适当的注释,这些都能让你的代码在几个月后,或者被其他同事接手时,不至于变成一堆“天书”。
  • 字符编码声明: 通常在里放一个,这能避免乱码问题,特别是处理多语言内容时,这是救命稻草。
  • 响应式基础: 这个标签几乎是现代网页的标配了,它告诉浏览器如何根据设备宽度来缩放页面。

至于如何修改HTML文件,这其实是个操作层面的问题,远没有规范那么“烧脑”,但也有一些小技巧:

  1. 选择你的武器: 任何文本编辑器都能干这事。从最简单的记事本(Windows)或TextEdit(macOS),到专业的代码编辑器,比如VS Code、Sublime Text、Notepad++。我强烈推荐VS Code,因为它有丰富的插件生态,能帮你自动补全、高亮代码,甚至帮你格式化,效率提升不是一点半点。
  2. 打开文件: 直接用你选的编辑器打开.html文件就行。
  3. 定位与修改: 根据你的需求,找到对应的标签、属性或者文本内容进行修改。比如想改个标题,就找到

    </code>标签;想换张图片,就找到<code><img></code>标签,修改<code>src</code>属性。</li><li><strong>保存:</strong> 这是最关键的一步,修改完一定要保存(Ctrl+S或Cmd+S)。</li><li><strong>浏览器刷新:</strong> 在浏览器里打开你的HTML文件,或者如果已经打开了,就刷新一下页面(F5或Ctrl+R/Cmd+R),看看你的修改是否生效。</li><li><strong>善用开发者工具:</strong> 浏览器自带的开发者工具(F12或右键检查)简直是神器。你可以在里面实时修改HTML和CSS,立即看到效果,而不用每次都保存文件再刷新。这对于调试和快速原型验证来说,效率高得惊人。</li></ol><h3>为什么遵循HTML语义化规范如此重要?</h3><p>语义化,这词儿听起来有点学院派,但它在实际开发中简直是基石。我个人觉得,它不仅仅是让代码看起来更“对”,更深层次的意义在于它极大地提升了网页的<strong>可访问性</strong>、<strong>搜索引擎优化(SEO)</strong>效果,以及团队协作时的<strong>可维护性</strong>。</p><img src="/uploads/20250803/1754212270688f27aee41ad.png" alt="HTML文档的编写规范是什么?如何修改HTML文件?"><p>你想想看,一个页面如果都是<code>div</code>和<code>span</code>堆砌起来的,那对于屏幕阅读器来说,它怎么知道哪个<code>div</code>是导航,哪个<code>div</code>是主要内容,哪个又是页脚呢?它只能按顺序“读”过去,用户体验会非常糟糕。但如果你用了<code><nav></code>、<code><main></code>、<code><footer></code>,屏幕阅读器就能明确告诉用户:“这里是导航区,这里是主要内容,这里是页脚。”这直接关系到残障人士能否顺畅地使用你的网站。</p><p>再说说SEO。搜索引擎的爬虫在抓取和解析网页时,也会优先理解那些结构清晰、语义明确的页面。一个语义化的页面,能让搜索引擎更快、更准确地理解你的内容重点,从而在搜索结果中获得更好的排名。你用了<code><h1></code>就代表这是最重要的标题,用了<code><article></code>就代表这是一篇独立完整的文章。这些信息对于搜索引擎来说都是非常宝贵的信号。</p><p>最后是可维护性。当你的项目越来越大,或者需要团队协作时,语义化的代码简直是救命稻草。你一眼就能看出某个区域的功能,而不是靠一堆<code>id</code>和<code>class</code>来猜测。这不仅减少了沟通成本,也降低了引入bug的风险,让新来的同事也能更快上手。我遇到过那种全是<code>div</code>的项目,每次修改都像是在拆弹,生怕动了这块儿,那块儿就崩了。所以,语义化,真不是为了“美观”,是为了“实用”和“长久”。</p><h3>在实际项目中,如何高效地修改和调试HTML代码?</h3><p>高效地修改和调试HTML代码,这可不仅仅是“打开文件,改,保存”那么简单。在真实的项目里,我们面对的是更复杂的场景,可能会有CSS、JavaScript的联动,甚至后端数据的动态渲染。</p><p>我个人最离不开的工具,毫无疑问就是<strong>浏览器开发者工具</strong>。无论是Chrome、Firefox还是Edge,它们内置的开发者工具都强大到难以置信。你可以直接在“Elements”(元素)面板里实时修改HTML结构、属性,甚至拖拽元素改变位置,同时在页面上看到即时反馈。这对于快速验证一个想法,或者定位某个布局问题,简直是神速。我经常会先在开发者工具里把样式和结构调到满意,然后再把这些修改复制回我的代码编辑器里。这比每次修改都保存、刷新页面要快上好几倍。</p><p>其次,<strong>版本控制系统</strong>,特别是Git,是现代开发不可或缺的一部分。你对HTML文件的每一次修改,都应该通过Git进行提交。这能让你随时回溯到之前的任何一个版本,就算你把文件改得一团糟,也能轻松恢复。我经历过因为手滑或者逻辑错误导致代码混乱的时刻,如果没有Git,那简直是灾难。</p><p>再来就是<strong>代码编辑器本身的功能</strong>。像VS Code这样的编辑器,提供了很多提高效率的功能:</p><ul><li><strong>Emmet语法:</strong> 敲几个字符就能生成一大段HTML代码,比如<code>div.container>ul>li*3>a</code>一敲回车,一套带class的无序列表就出来了,这速度谁用谁知道。</li><li><strong>代码格式化:</strong> Prettier或者EditorConfig这样的工具,能帮你自动格式化代码,保持统一的缩进和风格,避免团队成员之间代码风格不一致的问题。</li><li><strong>代码片段和自动补全:</strong> 输入几个字母,编辑器就能智能地提示你完整的标签或属性,大大减少了拼写错误和记忆负担。</li></ul><p>最后,我想说一个我常犯的“低级错误”:<strong>缓存问题</strong>。有时候你明明修改了HTML文件并保存了,但在浏览器里刷新却看不到变化。这时候,多半是浏览器缓存了旧的页面。强制刷新(Ctrl+Shift+R或Cmd+Shift+R)或者清空浏览器缓存,通常就能解决。还有就是<strong>路径问题</strong>,比如图片或CSS文件的路径写错了,导致资源加载失败,这时候开发者工具的“Console”(控制台)和“Network”(网络)面板就能派上大用场,它们会告诉你哪些资源加载失败了,以及失败的原因。</p><h3>除了基础标签,还有哪些HTML5新特性值得关注和应用?</h3><p>HTML5的出现,给前端开发带来了革命性的变化,它远不止是新增了几个语义化标签那么简单。除了我们前面提到的那些结构性标签,还有一些非常实用的新特性,它们极大地扩展了HTML的能力边界,让我们可以构建更丰富、更交互性强的网页应用。</p><p>首先,<strong>多媒体标签</strong>:<code><audio></code>和<code><video></code>。在HTML5之前,要在网页上播放音频和视频,我们通常需要依赖Flash这样的第三方插件,这不仅增加了页面的复杂性,也带来了安全和兼容性问题。现在,有了这两个标签,我们可以直接在浏览器中嵌入和控制音视频内容,而且它们提供了丰富的JavaScript API,可以自定义播放器界面、控制播放进度等等。我个人觉得,这彻底改变了多媒体在网页上的呈现方式。</p><p>其次,<strong>增强的表单控件和属性</strong>:HTML5为<code><input></code>标签引入了许多新的<code>type</code>属性,比如<code>type="email"</code>(自动验证邮箱格式)、<code>type="url"</code>(验证URL格式)、<code>type="date"</code>(日期选择器)、<code>type="number"</code>(只允许输入数字)等等。这些内置的验证和UI组件,大大简化了表单开发的工作量,同时也提升了用户体验。此外,<code>placeholder</code>(输入提示)、<code>required</code>(必填项)、<code>autofocus</code>(自动聚焦)这些属性也让表单变得更加智能和用户友好。</p><p>再者,<strong>客户端存储</strong>:<code>localStorage</code>和<code>sessionStorage</code>。它们提供了在用户浏览器中存储数据的能力。<code>localStorage</code>可以长期保存数据,即使关闭浏览器也不会丢失,非常适合存储用户的偏好设置、离线数据等。<code>sessionStorage</code>则只在当前会话期间有效,关闭浏览器或标签页就会清除。这比传统的<code>cookie</code>容量更大,也更易于使用,为离线应用和提升用户体验提供了强大的支持。</p><p>还有<strong>Canvas和SVG</strong>:这两个是绘图利器。<code>Canvas</code>是一个基于JavaScript的API,可以在网页上通过编程的方式绘制图形、动画,甚至处理图像和视频,非常适合游戏开发、数据可视化等场景。而<code>SVG</code>(Scalable Vector Graphics)则是一种基于XML的矢量图形格式,它可以在不失真的情况下任意缩放,非常适合图标、Logo等图形的展示。它们各自有其优势,但都极大地丰富了网页的视觉表现力。</p><p>最后,我想提一下*<em>Data属性(`data-</em><code>)**:这是一种非常灵活的自定义属性机制。你可以在任何HTML元素上添加以</code>data-<code>开头的自定义属性,然后通过JavaScript轻松地访问这些数据。这对于在HTML中存储一些与表现无关、但对JavaScript逻辑有用的数据非常方便,避免了把所有数据都塞到</code>id<code>或</code>class<code>里,让HTML结构更清晰。比如,</code>data-product-id="123"<code>,在JavaScript里通过</code>element.dataset.productId`就能获取到。这在构建复杂的交互组件时,简直是神器。</p><p>今天关于《HTML编写规范包括结构清晰、语义明确、代码简洁和易于维护。常见规范有:标签闭合、大小写统一、合理缩进、使用语义化标签、添加注释、属性有序排列、避免内联样式、声明文档类型。如何修改HTML文件?打开文件:用文本编辑器或IDE打开.html文件。编辑内容:修改标签内容,如标题。》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!</p> </div> <div class="labsList"> <a href="javascript:;" title="代码可读性">代码可读性</a> <a href="javascript:;" title="语义化">语义化</a> <a href="javascript:;" title="标签闭合">标签闭合</a> <a href="javascript:;" title="HTML规范">HTML规范</a> <a href="javascript:;" title="HTML5新特性">HTML5新特性</a> </div> <div class="cateBox"> <div class="cateItem"> <a href="/article/274291.html" title="HTML5视频标签使用详解与播放器推荐" class="img_box"> <img src="/uploads/20250803/1754212234688f278aa3566.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="HTML5视频标签使用详解与播放器推荐">HTML5视频标签使用详解与播放器推荐 </a> <dl> <dt class="lineOverflow"><a href="/article/274291.html" title="HTML5视频标签使用详解与播放器推荐" class="aBlack">上一篇<i></i></a></dt> <dd class="lineTwoOverflow">HTML5视频标签使用详解与播放器推荐</dd> </dl> </div> <div class="cateItem"> <a href="/article/274293.html" title="浏览器事件循环与渲染关系解析" class="img_box"> <img src="/uploads/20250803/1754212352688f2800ab0f6.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="浏览器事件循环与渲染关系解析"> </a> <dl> <dt class="lineOverflow"><a href="/article/274293.html" class="aBlack" title="浏览器事件循环与渲染关系解析">下一篇<i></i></a></dt> <dd class="lineTwoOverflow">浏览器事件循环与渲染关系解析</dd> </dl> </div> </div> </div> </div> <div class="leftContBox pt0"> <div class="pdl20"> <div class="contTit"> <a href="/articlelist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit">最新文章</div> </div> </div> <ul class="newArticleList"> <li> <div class="contBox"> <a href="/article/316517.html" class="img_box" title="HTML中引入CSS的正确写法及SEO建议"> <img src="/uploads/20250918/175817082868cb8ecc139e6.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="HTML中引入CSS的正确写法及SEO建议"> </a> <dl> <dd class="cont1"> <span> <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分钟前  |   <a href="javascript:;" class="aLightGray" title="CSS">CSS</a> <a href="javascript:;" class="aLightGray" title="引入">引入</a> <a href="javascript:;" class="aLightGray" title="Link标签">Link标签</a> <a href="javascript:;" class="aLightGray" title="样式表">样式表</a> <a href="javascript:;" class="aLightGray" title="HTMLhead">HTMLhead</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/316517.html" class="aBlack" target="_blank" title="HTML中引入CSS的正确写法及SEO建议">HTML中引入CSS的正确写法及SEO建议</a> </dt> <dd class="cont2"> <span><i class="view"></i>252浏览</span> <span class="collectBtn user_collection" data-id="316517" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316508.html" class="img_box" title="JavaScript闭包在SVG动画中的妙用解析"> <img src="/uploads/20250918/175816978268cb8ab67e70a.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="JavaScript闭包在SVG动画中的妙用解析"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  21分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/316508.html" class="aBlack" target="_blank" title="JavaScript闭包在SVG动画中的妙用解析">JavaScript闭包在SVG动画中的妙用解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>146浏览</span> <span class="collectBtn user_collection" data-id="316508" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316506.html" class="img_box" title="Nuxt3useFetch数据加载问题解析"> <img src="/uploads/20250918/175816965268cb8a348ff20.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="Nuxt3useFetch数据加载问题解析"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  23分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/316506.html" class="aBlack" target="_blank" title="Nuxt3useFetch数据加载问题解析">Nuxt3useFetch数据加载问题解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>156浏览</span> <span class="collectBtn user_collection" data-id="316506" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316503.html" class="img_box" title="CSS实现横向滚动方法详解"> <img src="/uploads/20250918/175816930268cb88d658e77.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS实现横向滚动方法详解"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  28分钟前  |   <a href="javascript:;" class="aLightGray" title="响应式设计">响应式设计</a> <a href="javascript:;" class="aLightGray" title="FLEXBOX">FLEXBOX</a> <a href="javascript:;" class="aLightGray" title="scroll-snap">scroll-snap</a> <a href="javascript:;" class="aLightGray" title="overflow-x:scroll">overflow-x:scroll</a> <a href="javascript:;" class="aLightGray" title="CSS横向滚动">CSS横向滚动</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/316503.html" class="aBlack" target="_blank" title="CSS实现横向滚动方法详解">CSS实现横向滚动方法详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>274浏览</span> <span class="collectBtn user_collection" data-id="316503" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316498.html" class="img_box" title="BOM调用文件系统API方法解析"> <img src="/uploads/20250918/175816888268cb8732082b9.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="BOM调用文件系统API方法解析"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  36分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/316498.html" class="aBlack" target="_blank" title="BOM调用文件系统API方法解析">BOM调用文件系统API方法解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>146浏览</span> <span class="collectBtn user_collection" data-id="316498" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316497.html" class="img_box" title="CSS如何设置边框样式"> <img src="/uploads/20250918/175816882068cb86f44ebeb.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS如何设置边框样式"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  37分钟前  |   <a href="javascript:;" class="aLightGray" title="CSS教程">CSS教程</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/316497.html" class="aBlack" target="_blank" title="CSS如何设置边框样式">CSS如何设置边框样式</a> </dt> <dd class="cont2"> <span><i class="view"></i>447浏览</span> <span class="collectBtn user_collection" data-id="316497" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316493.html" class="img_box" title="哈夫曼树与编码原理全解析"> <img src="/uploads/20250918/175816857668cb8600d7eb1.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="哈夫曼树与编码原理全解析"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  41分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/316493.html" class="aBlack" target="_blank" title="哈夫曼树与编码原理全解析">哈夫曼树与编码原理全解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>411浏览</span> <span class="collectBtn user_collection" data-id="316493" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316481.html" class="img_box" title="闭包如何运作?为何函数式编程离不开它?"> <img src="/uploads/20250918/175816751968cb81dfb6b34.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="闭包如何运作?为何函数式编程离不开它?"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>   |  58分钟前  |   <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="词法作用域">词法作用域</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/316481.html" class="aBlack" target="_blank" title="闭包如何运作?为何函数式编程离不开它?">闭包如何运作?为何函数式编程离不开它?</a> </dt> <dd class="cont2"> <span><i class="view"></i>148浏览</span> <span class="collectBtn user_collection" data-id="316481" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316479.html" class="img_box" title="约瑟夫问题是什么?JS实现解法详解"> <img src="/uploads/20250918/175816737568cb814fb3432.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="约瑟夫问题是什么?JS实现解法详解"> </a> <dl> <dd class="cont1"> <span> <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小时前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/316479.html" class="aBlack" target="_blank" title="约瑟夫问题是什么?JS实现解法详解">约瑟夫问题是什么?JS实现解法详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>174浏览</span> <span class="collectBtn user_collection" data-id="316479" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316475.html" class="img_box" title="CSS文字动态效果实现技巧"> <img src="/uploads/20250918/175816715268cb80705dd77.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS文字动态效果实现技巧"> </a> <dl> <dd class="cont1"> <span> <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小时前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/316475.html" class="aBlack" target="_blank" title="CSS文字动态效果实现技巧">CSS文字动态效果实现技巧</a> </dt> <dd class="cont2"> <span><i class="view"></i>118浏览</span> <span class="collectBtn user_collection" data-id="316475" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316467.html" class="img_box" title="CSS自定义边框样式全攻略"> <img src="/uploads/20250918/175816677768cb7ef90129f.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS自定义边框样式全攻略"> </a> <dl> <dd class="cont1"> <span> <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="CSS">CSS</a> <a href="javascript:;" class="aLightGray" title="border-radius">border-radius</a> <a href="javascript:;" class="aLightGray" title="边框样式">边框样式</a> <a href="javascript:;" class="aLightGray" title="border属性">border属性</a> <a href="javascript:;" class="aLightGray" title="border-image">border-image</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/316467.html" class="aBlack" target="_blank" title="CSS自定义边框样式全攻略">CSS自定义边框样式全攻略</a> </dt> <dd class="cont2"> <span><i class="view"></i>125浏览</span> <span class="collectBtn user_collection" data-id="316467" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/316449.html" class="img_box" title="CSS主题切换优化:文本颜色过渡慢解决方案"> <img src="/uploads/20250918/175816562168cb7a7539892.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS主题切换优化:文本颜色过渡慢解决方案"> </a> <dl> <dd class="cont1"> <span> <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小时前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/316449.html" class="aBlack" target="_blank" title="CSS主题切换优化:文本颜色过渡慢解决方案">CSS主题切换优化:文本颜色过渡慢解决方案</a> </dt> <dd class="cont2"> <span><i class="view"></i>203浏览</span> <span class="collectBtn user_collection" data-id="316449" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> </ul> </div> </div> <div class="mainRight"> <!-- 右侧广告位banner --> <div class="rightContBox" style="margin-top: 0px;"> <div class="rightTit"> <a href="/courselist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">课程推荐</div> </div> <ul class="lessonRecomRList"> <li> <a href="/course/9.html" class="img_box" target="_blank" title="前端进阶之JavaScript设计模式"> <img src="/uploads/20221222/52fd0f23a454c71029c2c72d206ed815.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="前端进阶之JavaScript设计模式"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/9.html" target="_blank" class="aBlack" title="前端进阶之JavaScript设计模式">前端进阶之JavaScript设计模式</a></dt> <dd class="cont1 lineTwoOverflow"> 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。 </dd> <dd class="cont2">543次学习</dd> </dl> </li> <li> <a href="/course/2.html" class="img_box" target="_blank" title="GO语言核心编程课程"> <img src="/uploads/20221221/634ad7404159bfefc6a54a564d437b5f.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="GO语言核心编程课程"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/2.html" target="_blank" class="aBlack" title="GO语言核心编程课程">GO语言核心编程课程</a></dt> <dd class="cont1 lineTwoOverflow"> 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。 </dd> <dd class="cont2">514次学习</dd> </dl> </li> <li> <a href="/course/74.html" class="img_box" target="_blank" title="简单聊聊mysql8与网络通信"> <img src="/uploads/20240103/bad35fe14edbd214bee16f88343ac57c.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="简单聊聊mysql8与网络通信"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/74.html" target="_blank" class="aBlack" title="简单聊聊mysql8与网络通信">简单聊聊mysql8与网络通信</a></dt> <dd class="cont1 lineTwoOverflow"> 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让 </dd> <dd class="cont2">499次学习</dd> </dl> </li> <li> <a href="/course/57.html" class="img_box" target="_blank" title="JavaScript正则表达式基础与实战"> <img src="/uploads/20221226/bbe4083bb3cb0dd135fb02c31c3785fb.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="JavaScript正则表达式基础与实战"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/57.html" target="_blank" class="aBlack" title="JavaScript正则表达式基础与实战">JavaScript正则表达式基础与实战</a></dt> <dd class="cont1 lineTwoOverflow"> 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。 </dd> <dd class="cont2">487次学习</dd> </dl> </li> <li> <a href="/course/28.html" class="img_box" target="_blank" title="从零制作响应式网站—Grid布局"> <img src="/uploads/20221223/ac110f88206daeab6c0cf38ebf5fe9ed.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="从零制作响应式网站—Grid布局"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/28.html" target="_blank" class="aBlack" title="从零制作响应式网站—Grid布局">从零制作响应式网站—Grid布局</a></dt> <dd class="cont1 lineTwoOverflow"> 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。 </dd> <dd class="cont2">484次学习</dd> </dl> </li> </ul> </div> <div class="rightContBox"> <div class="rightTit"> <a href="/ai.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">AI推荐</div> </div> <ul class="lessonRecomRList"> <li> <a href="/ai/13073.html" target="_blank" title="SEO AI Mermaid 流程图:自然语言生成,文本驱动可视化创作" class="img_box"> <img src="/uploads/20250909/175739760268bfc262225d4.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="SEO AI Mermaid 流程图:自然语言生成,文本驱动可视化创作" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13073.html" class="aBlack" target="_blank" title="AI Mermaid流程图">AI Mermaid流程图</a></dt> <dd class="cont1 lineTwoOverflow"> SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。 </dd> <dd class="cont2">752次使用</dd> </dl> </li> <li> <a href="/ai/13072.html" target="_blank" title="搜获客笔记生成器:小红书医美爆款内容AI创作神器" class="img_box"> <img src="/uploads/20250909/175742640268c032e21fd1a.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="搜获客笔记生成器:小红书医美爆款内容AI创作神器" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13072.html" class="aBlack" target="_blank" title="搜获客【笔记生成器】">搜获客【笔记生成器】</a></dt> <dd class="cont1 lineTwoOverflow"> 搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量! </dd> <dd class="cont2">768次使用</dd> </dl> </li> <li> <a href="/ai/13071.html" target="_blank" title="iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家" class="img_box"> <img src="/uploads/20250909/175738226468bf86788705c.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13071.html" class="aBlack" target="_blank" title="iTerms">iTerms</a></dt> <dd class="cont1 lineTwoOverflow"> iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。 </dd> <dd class="cont2">784次使用</dd> </dl> </li> <li> <a href="/ai/13070.html" target="_blank" title="TokenPony:AI大模型API聚合平台,一站式接入,高效稳定高性价比" class="img_box"> <img src="/uploads/20250910/175746240268c0bf82cfc51.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="TokenPony:AI大模型API聚合平台,一站式接入,高效稳定高性价比" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13070.html" class="aBlack" target="_blank" title="TokenPony">TokenPony</a></dt> <dd class="cont1 lineTwoOverflow"> TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。 </dd> <dd class="cont2">850次使用</dd> </dl> </li> <li> <a href="/ai/13069.html" target="_blank" title="迅捷AIPPT:AI智能PPT生成器,高效制作专业演示文稿" class="img_box"> <img src="/uploads/20250909/175739880268bfc71211053.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="迅捷AIPPT:AI智能PPT生成器,高效制作专业演示文稿" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13069.html" class="aBlack" target="_blank" title="迅捷AIPPT">迅捷AIPPT</a></dt> <dd class="cont1 lineTwoOverflow"> 迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。 </dd> <dd class="cont2">739次使用</dd> </dl> </li> </ul> </div> <!-- 相关文章 --> <div class="rightContBox"> <div class="rightTit"> <a href="/articlelist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">相关文章</div> </div> <ul class="aboutArticleRList"> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/72840.html" class="aBlack" title="优化用户界面体验的秘密武器:CSS开发项目经验大揭秘">优化用户界面体验的秘密武器:CSS开发项目经验大揭秘</a></dt> <dd> <span class="left">2023-11-03</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/76259.html" class="aBlack" title="使用微信小程序实现图片轮播特效">使用微信小程序实现图片轮播特效</a></dt> <dd> <span class="left">2023-11-21</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/83771.html" class="aBlack" title="解析sessionStorage的存储能力与限制">解析sessionStorage的存储能力与限制</a></dt> <dd> <span class="left">2024-01-11</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/85057.html" class="aBlack" title="探索冒泡活动对于团队合作的推动力">探索冒泡活动对于团队合作的推动力</a></dt> <dd> <span class="left">2024-01-13</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/91359.html" class="aBlack" title="UI设计中为何选择绝对定位的智慧之道">UI设计中为何选择绝对定位的智慧之道</a></dt> <dd> <span class="left">2024-02-03</span> <span class="right">501浏览</span> </dd> </dl> </li> </ul> </div> </div> </div> <div class="footer"> <div class="footerIn"> <div class="footLeft"> <div class="linkBox"> <a href="/about/1.html" target="_blank" class="aBlack" title="关于我们">关于我们</a> <a href="/about/5.html" target="_blank" class="aBlack" title="免责声明">免责声明</a> <a href="#" class="aBlack" title="意见反馈">意见反馈</a> <a href="/about/2.html" class="aBlack" target="_blank" title="联系我们">联系我们</a> <a href="/send.html" class="aBlack" title="广告合作">内容提交</a> </div> <div class="footTip">Golang学习网:公益在线Go学习平台,帮助Go学习者快速成长!</div> <div class="shareBox"> <span><i class="qq"></i>技术交流群</span> </div> <div class="copyRight"> Copyright 2023 http://www.17golang.com/ All Rights Reserved | <a href="https://beian.miit.gov.cn/" target="_blank" title="备案">苏ICP备2023003363号-1</a> </div> </div> <div class="footRight"> <ul class="encodeList"> <li> <div class="encodeImg"> <img src="/assets/examples/qrcode_for_gh.jpg" alt="Golang学习网"> </div> <div class="tit">关注公众号</div> <div class="tip">Golang学习网</div> </li> <div class="clear"></div> </ul> </div> <div class="clear"></div> </div> </div> <!-- 微信登录弹窗 --> <style> .popupBg .n-error{ color: red; } </style> <div class="popupBg"> <div class="loginBoxBox"> <div class="imgbg"> <img src="/assets/images/leftlogo.jpg" alt=""> </div> <!-- 微信登录 --> <div class="loginInfo encodeLogin" style="display: none;"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="changeLoginType cursorPointer create_wxqrcode" onclick="$('.loginInfo').hide();$('.passwordLogin').show();"> <div class="tip">密码登录在这里</div> </div> <div class="encodeInfo"> <div class="tit"><i></i> 微信扫码登录或注册</div> <div class="encodeImg"> <span id="wx_login_qrcode"><img src="/assets/examples/code.png" alt="二维码"></span> <!-- <div class="refreshBox"> <p>二维码失效</p> <button type="button" class="create_wxqrcode">刷新1111</button> </div> --> </div> <div class="tip">打开微信扫一扫,快速登录/注册</div> </div> <div class="beforeLoginTip">登录即同意 <a href="#" class="aBlue" title="用户协议">用户协议</a> 和 <a href="#" class="aBlue" title="隐私政策">隐私政策</a></div> </div> <!-- 密码登录 --> <div class="loginInfo passwordLogin"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="changeLoginType cursorPointer create_wxqrcode" onclick="$('.loginInfo').hide();$('.encodeLogin').show();"> <div class="tip">微信登录更方便</div> </div> <div class="passwordInfo"> <ul class="logintabs selfTabMenu"> <li class="selfTabItem loginFormLi curr">密码登录</li> <li class="selfTabItem registerFormBox ">注册账号</li> </ul> <div class="selfTabContBox"> <div class="selfTabCont loginFormBox" style="display: block;"> <form name="form" id="login-form" class="form-vertical form" method="POST" action="/index/user/login"> <input type="hidden" name="url" value="//www.17golang.com/article/274292.html"/> <input type="hidden" name="__token__" value="8a9e99b0bd02af9f7efeb26587977f35" /> <div class="form-group" style="height:70px;"> <input class="form-control" id="account" type="text" name="account" value="" data-rule="required" placeholder="邮箱/用户名" autocomplete="off"> </div> <div class="form-group" style="height:70px;"> <input class="form-control" id="password" type="password" name="password" data-rule="required;password" placeholder="密码" autocomplete="off"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" data-rule="required;length(4)" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <img src="/captcha.html" width="100" height="45" onclick="this.src = '/captcha.html?r=' + Math.random();"/> </span> </div> <div class="other"> <a href="#" class="forgetPwd aGray" onclick="$('.loginInfo').hide();$('.passwordForget').show();" title="忘记密码">忘记密码</a> </div> <div class="loginBtn mt25"> <button type="submit">登录</button> </div> </form> </div> <div class="selfTabCont registerFormBox" style="display: none;"> <form name="form1" id="register-form" class="form-vertical form" method="POST" action="/index/user/register"> <input type="hidden" name="invite_user_id" value="0"/> <input type="hidden" name="url" value="//www.17golang.com/article/274292.html"/> <input type="hidden" name="__token__" value="8a9e99b0bd02af9f7efeb26587977f35" /> <div class="form-group" style="height:70px;"> <input type="text" name="email" id="email2" data-rule="required;email" class="form-control" placeholder="邮箱"> </div> <div class="form-group" style="height:70px;"> <input type="text" id="username" name="username" data-rule="required;username" class="form-control" placeholder="用户名必须3-30个字符"> </div> <div class="form-group" style="height:70px;"> <input type="password" id="password2" name="password" data-rule="required;password" class="form-control" placeholder="密码必须6-30个字符"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" data-rule="required;length(4)" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <img src="/captcha.html" width="100" height="45" onclick="this.src = '/captcha.html?r=' + Math.random();"/> </span> </div> <div class="loginBtn"> <button type="submit">注册</button> </div> </form> </div> </div> </div> <div class="beforeLoginTip">登录即同意 <a href="https://www.17golang.com/about/3.html" target="_blank" class="aBlue" title="用户协议">用户协议</a> 和 <a href="https://www.17golang.com/about/4.html" target="_blank" class="aBlue" title="隐私政策">隐私政策</a></div> </div> <!-- 重置密码 --> <div class="loginInfo passwordForget"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="returnLogin cursorPointer" onclick="$('.passwordForget').hide();$('.passwordLogin').show();">返回登录</div> <div class="passwordInfo"> <ul class="logintabs selfTabMenu"> <li class="selfTabItem">重置密码</li> </ul> <div class="selfTabContBox"> <div class="selfTabCont"> <form id="resetpwd-form" class="form-horizontal form-layer nice-validator n-default n-bootstrap form" method="POST" action="/api/user/resetpwd.html" novalidate="novalidate"> <div style="height:70px;"> <input type="text" class="form-control" id="email" name="email" value="" placeholder="输入邮箱" aria-invalid="true"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <a href="javascript:;" class="btn btn-primary btn-captcha cursorPointer" style="background: #2080F8; border-radius: 4px; color: #fff; padding: 12px; position: absolute;" data-url="/api/ems/send.html" data-type="email" data-event="resetpwd">发送验证码</a> </span> </div> <input type="password" class="form-control" id="newpassword" name="newpassword" value="" placeholder="请输入6-18位密码"> <div class="loginBtn mt25"> <button type="submit">重置密码</button> </div> </form> </div> </div> </div> </div> </div> </div> <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/require.js" data-main="/assets/js/require-frontend.js?v=1671101972"></script> </body> </html>