当前位置:首页 > 文章列表 > 文章 > 前端 > 多行HTML注释的写法是使用<!--开始,-->结束,中间可以包含多行内容。以下是标准写法示范:<!--这是一个多行HTML注释示例可以写多行内容用于注释代码或临时隐藏内容-->这种注释方式在开发过程中非常有用,可以帮助开发者理解代码逻辑或暂时禁用某段代码。

多行HTML注释的写法是使用<!--开始,-->结束,中间可以包含多行内容。以下是标准写法示范:<!--这是一个多行HTML注释示例可以写多行内容用于注释代码或临时隐藏内容-->这种注释方式在开发过程中非常有用,可以帮助开发者理解代码逻辑或暂时禁用某段代码。

2025-10-05 23:34:57 0浏览 收藏

HTML注释是提升代码可维护性的关键!本文深入探讨了HTML多行注释的写法,标准语法为``,可跨越多行注释代码,便于复杂组件说明和团队协作。但需注意,HTML注释不支持嵌套,否则会导致页面解析错误。尽管注释会略微增加文件体积,但对页面性能影响甚微,且搜索引擎会忽略注释内容,因此不会直接影响SEO。最佳实践是在代码中合理使用注释,并在部署时通过压缩工具移除注释以优化性能。掌握多行注释的正确使用,能显著提升代码可读性,助力高效开发。

HTML注释支持多行,使用语法可注释任意行数内容,浏览器将其视为整体不渲染。多行注释适用于复杂组件说明、临时禁用代码、团队协作标记和解释非直观结构,提升代码可读性与维护效率。但HTML注释不可嵌套,否则会导致解析错误,使部分内容意外显示,破坏页面结构或泄露信息。尽管注释会略微增加文件体积,影响加载性能,但实际影响极小;SEO方面,搜索引擎忽略注释内容,不会直接作用于排名。最佳实践是合理使用注释增强可维护性,部署时通过压缩工具移除注释以优化性能。

HTML注释支持多行吗_多行HTML注释的标准写法示范

HTML注释确实支持多行。在HTML中,你只需要使用标准的注释语法,无论内容有多少行,它都会被浏览器整体视为一个注释块,不会被渲染到页面上。这使得开发者可以方便地为代码段、组件或任何需要详细说明的部分添加解释,而不用担心换行符会中断注释。

解决方案

要实现多行HTML注释,方法其实非常直接。你只需要在注释的开始标签之前,放入你所有需要注释的内容,即使这些内容跨越多行,浏览器也会正确识别。

例如,如果你想注释掉一个复杂的JavaScript脚本块,或者为一段HTML结构提供详细的背景信息,你可以这样做:


浏览器在解析这段代码时,会从为止,将这之间的所有内容都视为注释,不进行渲染。所以,无论你的注释内容有多少行,它都会被视为一个完整的注释单元。这在我日常的开发工作中,是保持代码可读性和可维护性不可或缺的工具。

HTML多行注释的最佳实践与场景应用

在我看来,多行HTML注释远不止是“把代码藏起来”那么简单,它更是代码沟通和维护的艺术。我个人在实践中发现,有几个场景特别适合使用多行注释,并且遵循一些小习惯能让它们发挥更大的作用。

首先,复杂组件或模块的概览说明。当你构建一个大型前端应用时,一个页面往往由多个独立的组件构成。在每个组件的HTML结构开始处,用多行注释写下这个组件的核心功能、它解决的问题、重要的CSS类名或JavaScript交互点。这就像是给组件写了一份迷你说明书。想象一下,几个月后你或你的同事回来修改,一眼就能抓住重点,这能省下大量摸索的时间。

其次,临时禁用大段代码。开发过程中,我们经常需要测试不同的实现方案,或者暂时移除某个功能。与其删除代码,不如用多行注释将其“冻结”起来。这样,如果后面需要恢复,或者发现新方案有问题,旧代码还能随时取回。我个人就经常在迭代时,把旧的UI逻辑整个注释掉,等新逻辑稳定后再彻底清理。

再者,团队协作中的备忘录或问题标记。有时候,你可能在某个地方遇到了一个棘手的问题,或者有待优化的地方,但当下没时间解决。用一个带有你的名字和日期的多行注释标记出来,比如。这比散落在聊天记录里的信息更直接、更具上下文。

最后,解释非显而易见的结构或魔法数字。某些HTML结构可能为了满足特定的CSS布局或者JS交互而显得有些“奇怪”,或者你用了某个数字作为ID或类名有其特殊含义。多行注释可以用来解释这些“为什么”。比如,一个空的div可能只是为了清除浮动,或者一个特定的data-id有其后端逻辑关联。这些细节如果不明说,后来者真的会一头雾水。

总的来说,多行注释是提升代码可读性、促进团队协作、简化未来维护的利器。关键在于,要让它们真正提供价值,而不是仅仅堆砌文字。

在HTML注释中嵌套注释会引发什么问题?

这是一个我曾亲身踩过的坑,也看到不少新手开发者会犯的错误:尝试在HTML注释内部再嵌套一个HTML注释。简单来说,HTML注释是不能嵌套的。一旦你尝试这样做,它会立即导致你的页面渲染出现问题,而不是你期望的“注释掉注释”。

HTML注释的解析机制是这样的:浏览器会从。一旦找到这个结束标记,它就会认为整个注释块已经结束了。

举个例子:


  

这段文字不应该出现,但它会显示在页面上。

-->

这是注释外部的正常内容。

当你运行这段代码时,你会发现这是一个外部注释的开始(内部注释的结束符)开始,到外部注释的结束符-->之间的内容,也就是

这段文字不应该出现,但它会显示在页面上。

会被浏览器错误地解析并渲染出来

这会带来几个问题:

  1. 页面布局混乱:原本不应该显示的内容突然出现在页面上,可能破坏设计。
  2. 信息泄露:如果你在内部注释中包含了敏感信息(比如一些临时的API密钥或调试信息),它们可能会意外地暴露给用户。
  3. 调试困难:这种不符合预期的行为会让你很难追踪问题,因为你以为代码被注释了,但它实际上还在影响页面。

所以,我的建议是,绝对不要在HTML注释中嵌套其他HTML注释。如果你需要临时注释掉一段已经包含注释的代码,最稳妥的做法是暂时移除内部的注释标记,或者使用你的代码编辑器提供的块注释功能(通常是语言无关的,例如某些IDE的“折叠”或“禁用”功能),而不是依赖HTML自身的注释机制。记住,HTML注释的边界是严格且不容侵犯的。

HTML注释对页面性能和SEO有哪些潜在影响?

关于HTML注释对页面性能和SEO的影响,这其实是一个经常被提及,但又常常被误解的话题。在我看来,它更像是一个“微观影响”而非“宏观影响”,但理解这些细节仍然是专业开发者的必备素质。

对页面性能的影响:

从技术层面讲,HTML注释确实会增加页面的文件大小。因为注释内容也是文件的一部分,浏览器在下载HTML文件时,会把它们一同下载下来。理论上,文件越大,下载时间就越长,从而影响页面加载速度。

然而,这种影响在绝大多数情况下都是微乎其微的。现代网络带宽和浏览器解析速度都非常快,除非你的HTML文件包含了数万行甚至数十万行的注释(这本身就是一种代码异味),否则那几十KB或几百KB的注释内容对整体性能的影响几乎可以忽略不计。浏览器解析HTML时,会识别并跳过注释块,并不会花费大量计算资源去处理它们。

我个人在项目实践中,并不会为了那点微不足道的性能提升而放弃注释。代码的可读性和可维护性带来的长期效益,远超那点文件大小的增加。当然,如果你追求极致优化,或者你的网站流量巨大且用户分布在全球各地,那么在部署前使用HTML压缩/Minification工具是一个好习惯。这些工具通常会在不影响代码功能的前提下,自动移除HTML文件中的所有注释、空白符和换行符,从而真正减小文件大小,提升加载速度。

对SEO(搜索引擎优化)的影响:

这是一个更明确的结论:HTML注释对SEO几乎没有直接影响。搜索引擎的爬虫在抓取和索引网页内容时,会像浏览器一样识别并忽略HTML注释。它们不会将注释中的文本视为页面内容的一部分来参与排名计算。

这意味着:

  1. 不要尝试在注释中“隐藏”关键词:有些开发者可能会想,把大量关键词塞到注释里,希望能骗过搜索引擎。这不仅无效,而且如果被搜索引擎发现有这种“黑帽SEO”行为,反而可能导致你的网站被降权。
  2. 注释是给开发者看的,不是给搜索引擎看的:你写注释是为了方便自己和团队理解和维护代码,而不是为了提升搜索引擎排名。页面上的实际、可见内容,以及元数据(如</code>、<code><meta description></code>)才是对SEO真正重要的。</li></ol><p>当然,也有一些非常间接的影响。一个维护良好、代码清晰的网站,开发者更容易快速迭代、修复bug、优化用户体验。而一个稳定、快速、用户体验良好的网站,往往能在用户留存和间接的排名因素上获得优势。但这是“好代码”带来的间接效益,并非HTML注释本身的直接SEO价值。</p><p>总而言之,在权衡注释与性能/SEO时,我始终倾向于优先考虑代码的可读性和可维护性。合理、有价值的注释是好代码的一部分,而极致的性能优化则应该通过专业的压缩工具来完成,而不是以牺牲代码可读性为代价。</p><p>到这里,我们也就讲完了《多行HTML注释的写法是使用<!--开始,-->结束,中间可以包含多行内容。以下是标准写法示范:<!--这是一个多行HTML注释示例可以写多行内容用于注释代码或临时隐藏内容-->这种注释方式在开发过程中非常有用,可以帮助开发者理解代码逻辑或暂时禁用某段代码。》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于SEO,页面性能,多行注释,HTML注释,代码可维护性的知识点!</p> </div> <div class="labsList"> <a href="javascript:;" title="SEO">SEO</a> <a href="javascript:;" title="页面性能">页面性能</a> <a href="javascript:;" title="多行注释">多行注释</a> <a href="javascript:;" title="HTML注释">HTML注释</a> <a href="javascript:;" title="代码可维护性">代码可维护性</a> </div> <div class="cateBox"> <div class="cateItem"> <a href="/article/335952.html" title="PHP递归解析嵌套评论的实现方法" class="img_box"> <img src="/uploads/20251005/175967841368e28fcd95da2.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="PHP递归解析嵌套评论的实现方法">PHP递归解析嵌套评论的实现方法 </a> <dl> <dt class="lineOverflow"><a href="/article/335952.html" title="PHP递归解析嵌套评论的实现方法" class="aBlack">上一篇<i></i></a></dt> <dd class="lineTwoOverflow">PHP递归解析嵌套评论的实现方法</dd> </dl> </div> <div class="cateItem"> <a href="/article/335954.html" title="拼多多退货被拒怎么办" class="img_box"> <img src="/uploads/20251005/175967853268e290441b622.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="拼多多退货被拒怎么办"> </a> <dl> <dt class="lineOverflow"><a href="/article/335954.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/620112.html" class="img_box" title="前端发布后白屏复盘:Service Worker 缓存旧入口导致 JS 资源 404"> <img src="/uploads/20260630/1782799139-sw-old-entry-404-path.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端发布后白屏复盘:Service Worker 缓存旧入口导致 JS 资源 404"> </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>   |  15小时前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/322_new_0_1.html" class="aLightGray" title="缓存">缓存</a> · <a href="/articletag/14884_new_0_1.html" class="aLightGray" title="Service Worker">Service Worker</a> · <a href="/articletag/40077_new_0_1.html" class="aLightGray" title="白屏">白屏</a> · <a href="/articletag/40078_new_0_1.html" class="aLightGray" title="发布故障">发布故障</a> · <a href="javascript:;" class="aLightGray" title="缓存策略">缓存策略</a> <a href="javascript:;" class="aLightGray" title="前端白屏">前端白屏</a> <a href="javascript:;" class="aLightGray" title="Service Worker">Service Worker</a> <a href="javascript:;" class="aLightGray" title="CacheStorage">CacheStorage</a> <a href="javascript:;" class="aLightGray" title="资源404">资源404</a> <a href="javascript:;" class="aLightGray" title="发布回滚">发布回滚</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620112.html" class="aBlack" target="_blank" title="前端发布后白屏复盘:Service Worker 缓存旧入口导致 JS 资源 404">前端发布后白屏复盘:Service Worker 缓存旧入口导致 JS 资源 404</a> </dt> <dd class="cont2"> <span><i class="view"></i>469浏览</span> <span class="collectBtn user_collection" data-id="620112" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620092.html" class="img_box" title="前端批量导出接口怎么设计:异步任务、状态查询和下载链接"> <img src="/uploads/20260629/1782718967-export-api-error-panel.webp" 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>   |  1天前  |   <a href="/articletag/2436_new_0_1.html" class="aLightGray" title="异步任务">异步任务</a> · <a href="/articletag/5401_new_0_1.html" class="aLightGray" title="前端开发">前端开发</a> · <a href="/articletag/39770_new_0_1.html" class="aLightGray" title="接口设计">接口设计</a> · <a href="/articletag/40045_new_0_1.html" class="aLightGray" title="后台系统">后台系统</a> · <a href="/articletag/40046_new_0_1.html" 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> <a href="javascript:;" class="aLightGray" title="状态查询">状态查询</a> <a href="javascript:;" class="aLightGray" title="报表导出">报表导出</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620092.html" class="aBlack" target="_blank" title="前端批量导出接口怎么设计:异步任务、状态查询和下载链接">前端批量导出接口怎么设计:异步任务、状态查询和下载链接</a> </dt> <dd class="cont2"> <span><i class="view"></i>296浏览</span> <span class="collectBtn user_collection" data-id="620092" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620091.html" class="img_box" title="前端表格列设置刷新后丢失怎么办:可见列、列宽和顺序这样保存"> <img src="/uploads/20260629/1782717813-frontend-table-columns-lifecycle.webp" 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>   |  1天前  |   <a href="/articletag/5401_new_0_1.html" class="aLightGray" title="前端开发">前端开发</a> · <a href="/articletag/39813_new_0_1.html" class="aLightGray" title="localStorage">localStorage</a> · <a href="/articletag/40043_new_0_1.html" class="aLightGray" title="表格配置">表格配置</a> · <a href="/articletag/40044_new_0_1.html" class="aLightGray" title="用户偏好">用户偏好</a> · <a href="/articletag/40045_new_0_1.html" class="aLightGray" title="后台系统">后台系统</a> · <a href="javascript:;" class="aLightGray" title="用户偏好">用户偏好</a> <a href="javascript:;" class="aLightGray" title="localStorage">localStorage</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/620091.html" class="aBlack" target="_blank" title="前端表格列设置刷新后丢失怎么办:可见列、列宽和顺序这样保存">前端表格列设置刷新后丢失怎么办:可见列、列宽和顺序这样保存</a> </dt> <dd class="cont2"> <span><i class="view"></i>351浏览</span> <span class="collectBtn user_collection" data-id="620091" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620087.html" class="img_box" title="前端实时通知方案选型:短轮询、SSE、WebSocket 怎么选"> <img src="/uploads/20260629/1782712475-frontend-notify-choice-timeline.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端实时通知方案选型:短轮询、SSE、WebSocket 怎么选"> </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="/articletag/1017_new_0_1.html" class="aLightGray" title="websocket">websocket</a> · <a href="/articletag/5401_new_0_1.html" class="aLightGray" title="前端开发">前端开发</a> · <a href="/articletag/27659_new_0_1.html" class="aLightGray" title="sse">sse</a> · <a href="/articletag/40036_new_0_1.html" class="aLightGray" title="实时通知">实时通知</a> · <a href="/articletag/40037_new_0_1.html" class="aLightGray" title="方案选型">方案选型</a> · <a href="javascript:;" class="aLightGray" title="websocket">websocket</a> <a href="javascript:;" class="aLightGray" title="消息推送">消息推送</a> <a href="javascript:;" class="aLightGray" title="EventSource">EventSource</a> <a href="javascript:;" class="aLightGray" title="SSE">SSE</a> <a href="javascript:;" class="aLightGray" title="前端实时通知">前端实时通知</a> <a href="javascript:;" class="aLightGray" title="短轮询">短轮询</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620087.html" class="aBlack" target="_blank" title="前端实时通知方案选型:短轮询、SSE、WebSocket 怎么选">前端实时通知方案选型:短轮询、SSE、WebSocket 怎么选</a> </dt> <dd class="cont2"> <span><i class="view"></i>498浏览</span> <span class="collectBtn user_collection" data-id="620087" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620079.html" class="img_box" title="前端接口超时告警运行手册:从瀑布图到降级回滚"> <img src="/uploads/20260629/1782702426-frontend-api-timeout-alert-flow.webp" 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>   |  1天前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/40002_new_0_1.html" class="aLightGray" title="接口排查">接口排查</a> · <a href="/articletag/40021_new_0_1.html" class="aLightGray" title="运维手册">运维手册</a> · <a href="/articletag/40024_new_0_1.html" class="aLightGray" title="性能告警">性能告警</a> · <a href="javascript:;" class="aLightGray" title="前端">前端</a> <a href="javascript:;" class="aLightGray" title="AbortController">AbortController</a> <a href="javascript:;" class="aLightGray" title="接口超时">接口超时</a> <a href="javascript:;" class="aLightGray" title="Network瀑布图">Network瀑布图</a> <a href="javascript:;" class="aLightGray" title="降级回滚">降级回滚</a> <a href="javascript:;" class="aLightGray" title="线上告警">线上告警</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620079.html" class="aBlack" target="_blank" title="前端接口超时告警运行手册:从瀑布图到降级回滚">前端接口超时告警运行手册:从瀑布图到降级回滚</a> </dt> <dd class="cont2"> <span><i class="view"></i>287浏览</span> <span class="collectBtn user_collection" data-id="620079" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620076.html" class="img_box" title="CSS sticky 不生效排查清单:从 top、overflow 到滚动容器逐层定位"> <img src="/uploads/20260629/1782698249-css-sticky-failure-check.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS sticky 不生效排查清单:从 top、overflow 到滚动容器逐层定位"> </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="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/4729_new_0_1.html" class="aLightGray" title="css">css</a> · <a href="/articletag/9935_new_0_1.html" class="aLightGray" title="sticky">sticky</a> · <a href="/articletag/40022_new_0_1.html" class="aLightGray" title="布局调试">布局调试</a> · <a href="javascript:;" class="aLightGray" title="CSS">CSS</a> <a href="javascript:;" class="aLightGray" title="Overflow">Overflow</a> <a href="javascript:;" class="aLightGray" title="position sticky">position sticky</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/620076.html" class="aBlack" target="_blank" title="CSS sticky 不生效排查清单:从 top、overflow 到滚动容器逐层定位">CSS sticky 不生效排查清单:从 top、overflow 到滚动容器逐层定位</a> </dt> <dd class="cont2"> <span><i class="view"></i>179浏览</span> <span class="collectBtn user_collection" data-id="620076" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620069.html" class="img_box" title="前端静态资源上云部署选型:对象存储、CDN 和容器服务怎么选"> <img src="/uploads/20260627/1782572123-frontend-static-cache-architecture.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端静态资源上云部署选型:对象存储、CDN 和容器服务怎么选"> </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="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/652_new_0_1.html" class="aLightGray" title="静态资源">静态资源</a> · <a href="/articletag/5322_new_0_1.html" class="aLightGray" title="cdn">cdn</a> · <a href="/articletag/40011_new_0_1.html" 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="cdn">cdn</a> <a href="javascript:;" class="aLightGray" title="前端部署">前端部署</a> <a href="javascript:;" class="aLightGray" title="容器服务">容器服务</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620069.html" class="aBlack" target="_blank" title="前端静态资源上云部署选型:对象存储、CDN 和容器服务怎么选">前端静态资源上云部署选型:对象存储、CDN 和容器服务怎么选</a> </dt> <dd class="cont2"> <span><i class="view"></i>433浏览</span> <span class="collectBtn user_collection" data-id="620069" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620045.html" class="img_box" title="前端表单重复提交防护工作流:从按钮状态到请求取消和幂等键"> <img src="/uploads/20260622/1782110788-frontend-idempotent-key-flow.webp" 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>   |  1星期前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/39982_new_0_1.html" class="aLightGray" title="接口联调">接口联调</a> · <a href="/articletag/39989_new_0_1.html" class="aLightGray" title="表单交互">表单交互</a> · <a href="/articletag/39990_new_0_1.html" class="aLightGray" title="重复提交">重复提交</a> · <a href="/articletag/39991_new_0_1.html" 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="AbortController">AbortController</a> <a href="javascript:;" class="aLightGray" title="幂等键">幂等键</a> <a href="javascript:;" class="aLightGray" title="按钮禁用">按钮禁用</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620045.html" class="aBlack" target="_blank" title="前端表单重复提交防护工作流:从按钮状态到请求取消和幂等键">前端表单重复提交防护工作流:从按钮状态到请求取消和幂等键</a> </dt> <dd class="cont2"> <span><i class="view"></i>374浏览</span> <span class="collectBtn user_collection" data-id="620045" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620039.html" class="img_box" title="前端 CORS 预检失败排查流程:从请求头到网关响应"> <img src="/uploads/20260618/1781767364-frontend-cors-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端 CORS 预检失败排查流程:从请求头到网关响应"> </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="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/4720_new_0_1.html" class="aLightGray" title="cors">cors</a> · <a href="/articletag/39980_new_0_1.html" class="aLightGray" title="跨域排查">跨域排查</a> · <a href="/articletag/39981_new_0_1.html" class="aLightGray" title="浏览器网络">浏览器网络</a> · <a href="/articletag/39982_new_0_1.html" class="aLightGray" title="接口联调">接口联调</a> · <a href="javascript:;" class="aLightGray" title="前端">前端</a> <a href="javascript:;" class="aLightGray" title="cors">cors</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="Options">Options</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620039.html" class="aBlack" target="_blank" title="前端 CORS 预检失败排查流程:从请求头到网关响应">前端 CORS 预检失败排查流程:从请求头到网关响应</a> </dt> <dd class="cont2"> <span><i class="view"></i>422浏览</span> <span class="collectBtn user_collection" data-id="620039" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620035.html" class="img_box" title="前端 position sticky 不生效排查:从滚动容器到 overflow 限制"> <img src="/uploads/20260618/1781761300-frontend-sticky-check-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端 position sticky 不生效排查:从滚动容器到 overflow 限制"> </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="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/4729_new_0_1.html" class="aLightGray" title="css">css</a> · <a href="/articletag/9935_new_0_1.html" class="aLightGray" title="sticky">sticky</a> · <a href="/articletag/39972_new_0_1.html" class="aLightGray" title="布局排查">布局排查</a> · <a href="/articletag/39973_new_0_1.html" class="aLightGray" title="滚动容器">滚动容器</a> · <a href="javascript:;" class="aLightGray" title="CSS">CSS</a> <a href="javascript:;" class="aLightGray" title="前端">前端</a> <a href="javascript:;" class="aLightGray" title="Overflow">Overflow</a> <a href="javascript:;" class="aLightGray" title="position sticky">position sticky</a> <a href="javascript:;" class="aLightGray" title="滚动容器">滚动容器</a> <a href="javascript:;" class="aLightGray" title="吸顶失效">吸顶失效</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620035.html" class="aBlack" target="_blank" title="前端 position sticky 不生效排查:从滚动容器到 overflow 限制">前端 position sticky 不生效排查:从滚动容器到 overflow 限制</a> </dt> <dd class="cont2"> <span><i class="view"></i>449浏览</span> <span class="collectBtn user_collection" data-id="620035" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620015.html" class="img_box" title="前端图片懒加载实战:首屏 LCP 与滚动加载完整流程"> <img src="/uploads/20260617/1781673768-frontend-image-lazyload-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端图片懒加载实战:首屏 LCP 与滚动加载完整流程"> </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="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/729_new_0_1.html" class="aLightGray" title="性能优化">性能优化</a> · <a href="/articletag/39948_new_0_1.html" 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="IntersectionObserver">IntersectionObserver</a> <a href="javascript:;" class="aLightGray" title="LCP">LCP</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620015.html" class="aBlack" target="_blank" title="前端图片懒加载实战:首屏 LCP 与滚动加载完整流程">前端图片懒加载实战:首屏 LCP 与滚动加载完整流程</a> </dt> <dd class="cont2"> <span><i class="view"></i>105浏览</span> <span class="collectBtn user_collection" data-id="620015" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620013.html" class="img_box" title="前端表单联动校验失效排查:旧状态、重复提交和提交锁"> <img src="/uploads/20260617/1781671884-frontend-form-bug-flow.webp" 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>   |  1星期前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/729_new_0_1.html" class="aLightGray" title="性能优化">性能优化</a> · <a href="/articletag/39947_new_0_1.html" class="aLightGray" title="表单校验">表单校验</a> · <a href="javascript:;" class="aLightGray" title="JavaScript">JavaScript</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/620013.html" class="aBlack" target="_blank" title="前端表单联动校验失效排查:旧状态、重复提交和提交锁">前端表单联动校验失效排查:旧状态、重复提交和提交锁</a> </dt> <dd class="cont2"> <span><i class="view"></i>285浏览</span> <span class="collectBtn user_collection" data-id="620013" 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">516次学习</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">500次学习</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">485次学习</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/13109.html" target="_blank" title="ljg-skills - "Prompt之神"李继刚开源的 AI 技能集" class="img_box"> <img src="/uploads/ai/20260616/ljg-skills-icon-8bbe1468e5.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="ljg-skills - "Prompt之神"李继刚开源的 AI 技能集" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13109.html" class="aBlack" target="_blank" title="ljg-skills">ljg-skills</a></dt> <dd class="cont1 lineTwoOverflow"> ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。 </dd> <dd class="cont2">3073次使用</dd> </dl> </li> <li> <a href="/ai/13108.html" target="_blank" title="MELO音乐 - AI 音乐生成平台,支持多模态创作能力" class="img_box"> <img src="/uploads/ai/20260616/melo-icon-10bf590762.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="MELO音乐 - AI 音乐生成平台,支持多模态创作能力" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13108.html" class="aBlack" target="_blank" title="MELO音乐">MELO音乐</a></dt> <dd class="cont1 lineTwoOverflow"> MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款! </dd> <dd class="cont2">2832次使用</dd> </dl> </li> <li> <a href="/ai/13107.html" target="_blank" title="UniScribe - AI 免费在线音视频转文字平台" class="img_box"> <img src="/uploads/ai/20260616/uniscribe-icon-3c88366a15.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="UniScribe - AI 免费在线音视频转文字平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13107.html" class="aBlack" target="_blank" title="UniScribe">UniScribe</a></dt> <dd class="cont1 lineTwoOverflow"> UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。 </dd> <dd class="cont2">2778次使用</dd> </dl> </li> <li> <a href="/ai/13106.html" target="_blank" title="剧云 - 免费 AI 智能中文剧本创作平台" class="img_box"> <img src="/uploads/ai/20260615/d36c7176-icon-2b0cd581ce.png" 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/13106.html" class="aBlack" target="_blank" title="剧云">剧云</a></dt> <dd class="cont1 lineTwoOverflow"> 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。 </dd> <dd class="cont2">2996次使用</dd> </dl> </li> <li> <a href="/ai/13105.html" target="_blank" title="万象有声 - AI 一站式有声内容创作平台" class="img_box"> <img src="/uploads/ai/20260615/50267bac-icon-c146b001b5.png" 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/13105.html" class="aBlack" target="_blank" title="万象有声">万象有声</a></dt> <dd class="cont1 lineTwoOverflow"> 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单! </dd> <dd class="cont2">2952次使用</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/207000.html" class="aBlack" title="JavaScript函数定义及示例详解">JavaScript函数定义及示例详解</a></dt> <dd> <span class="left">2025-05-11</span> <span class="right">502浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/619053.html" class="aBlack" title="CSS变量简化按钮悬停效果技巧">CSS变量简化按钮悬停效果技巧</a></dt> <dd> <span class="left">2026-05-31</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/618916.html" class="aBlack" title="JavaScript符号类型详解与应用">JavaScript符号类型详解与应用</a></dt> <dd> <span class="left">2026-05-31</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/612539.html" class="aBlack" title="HTML剪贴板复制粘贴怎么用">HTML剪贴板复制粘贴怎么用</a></dt> <dd> <span class="left">2026-05-26</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/611774.html" class="aBlack" title="data-*属性详解:HTML数据存储与DOM操作技巧">data-*属性详解:HTML数据存储与DOM操作技巧</a></dt> <dd> <span class="left">2026-05-25</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> <a href="/manual/go/" target="_blank" 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/335953.html"/> <input type="hidden" name="__token__" value="450ab7d8e5ec374aaf69281b9a8bbe9a" /> <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/335953.html"/> <input type="hidden" name="__token__" value="450ab7d8e5ec374aaf69281b9a8bbe9a" /> <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 src="/assets/js/juejin-theme.js?v=20260613b" defer></script> <script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?3dc5666f6478c7bf39cd5c91e597423d"; hm.async = true; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script> <script src="/assets/js/frontend/common.js"></script> </body> </html>