当前位置:首页 > 文章列表 > 文章 > 前端 > JS如何解析XML?3种常用方法超详细教程

JS如何解析XML?3种常用方法超详细教程

2025-06-21 15:45:18 0浏览 收藏

想知道**JS怎么解析XML**吗?本文手把手教你三种常用的JavaScript解析XML数据的方法,轻松搞定XML数据处理!主要介绍`DOMParser`、`XMLHttpRequest`和第三方库(如jQuery)这三种方案。`DOMParser`作为浏览器内置解析器,能将XML字符串转换为Document对象;`XMLHttpRequest`则用于从服务器获取XML文件,配合`responseXML`属性进行解析;而jQuery等第三方库则提供更简洁的API,如`$.parseXML()`,简化解析流程。文章还讲解了如何处理XML命名空间、复杂结构,以及错误处理,助你根据实际需求选择最合适的方案,高效解析XML数据。

解析 XML 数据在 JavaScript 中可通过三种主要方法实现:DOMParser、XMLHttpRequest 和第三方库。1.DOMParser 是浏览器内置的解析器,通过 parseFromString() 方法将 XML 字符串转换为 Document 对象,便于操作 XML DOM;2.XMLHttpRequest 可用于从服务器获取并解析 XML 文件,设置 responseType 为 "document" 后通过 responseXML 获取解析后的 Document 对象;3.第三方库如 jQuery 提供更简洁的 API,使用 $.parseXML() 方法简化解析和数据提取过程。此外,处理命名空间需使用 getElementsByTagNameNS() 和 getAttributeNS() 方法;复杂结构可通过递归函数遍历元素和属性;错误处理则应检查 parsererror 元素以判断解析是否失败。每种方法各有适用场景,开发者可根据需求选择合适方案。

js如何解析XML数据 XML数据解析的3种常用方法解析

直接使用 JavaScript 解析 XML 数据,核心在于将 XML 字符串转换为 JavaScript 可以操作的对象。通常有三种常见方法:DOMParser、XMLHttpRequest (配合 responseXML) 以及使用第三方库(例如 jQuery)。选择哪种方法取决于你的具体需求,比如是否需要兼容老版本浏览器,或者是否需要更便捷的 API。

js如何解析XML数据 XML数据解析的3种常用方法解析

DOMParser XMLHttpRequest 第三方库

js如何解析XML数据 XML数据解析的3种常用方法解析

DOMParser 解析 XML 数据

DOMParser 是浏览器内置的 XML 解析器,使用起来相当直接。首先,你需要创建一个 DOMParser 实例,然后调用其 parseFromString() 方法将 XML 字符串转换为 Document 对象。之后,你就可以像操作 HTML DOM 一样操作 XML DOM 了。

const xmlString = `
  
    Everyday Italian
    Giada De Laurentiis
    2005
    30.00
  
`;

const parser = new DOMParser();
const xmlDoc = parser.parseFromString(xmlString, "text/xml");

const title = xmlDoc.getElementsByTagName("title")[0].childNodes[0].nodeValue;
console.log(title); // 输出 "Everyday Italian"

需要注意的是,如果 XML 格式不正确,parseFromString() 方法可能会返回一个包含错误信息的 Document 对象。因此,在使用前最好检查一下 xmlDoc.getElementsByTagName("parsererror") 是否为空。

js如何解析XML数据 XML数据解析的3种常用方法解析

XMLHttpRequest 获取并解析 XML 数据

如果你需要从服务器获取 XML 数据,XMLHttpRequest 是一个不错的选择。设置 responseType 为 "document" 可以让浏览器自动将响应解析为 XML Document 对象。

const xhr = new XMLHttpRequest();
xhr.open("GET", "books.xml", true);
xhr.responseType = "document";

xhr.onload = function() {
  if (xhr.readyState === 4 && xhr.status === 200) {
    const xmlDoc = xhr.responseXML;
    const title = xmlDoc.getElementsByTagName("title")[0].textContent;
    console.log(title);
  }
};

xhr.send();

这里,books.xml 应该是一个 XML 文件,放置在你的服务器上。注意处理 readyStatestatus,确保请求成功完成。textContent 属性是获取元素文本内容的更简洁的方式,替代了 childNodes[0].nodeValue

使用第三方库简化 XML 解析

像 jQuery 这样的库提供了更简洁的 API 来处理 XML 数据。虽然 jQuery 主要用于 HTML 操作,但它也能很好地处理 XML。

const xmlString = `
  
    Everyday Italian
    Giada De Laurentiis
    2005
    30.00
  
`;

const xmlDoc = $.parseXML(xmlString);
const $xml = $(xmlDoc);

const title = $xml.find("title").text();
console.log(title); // 输出 "Everyday Italian"

$.parseXML() 将 XML 字符串转换为 XML Document 对象,然后你可以使用 jQuery 的选择器和遍历方法来查找和提取数据。这种方式通常更简洁,代码可读性也更高。

如何处理 XML 中的命名空间?

XML 命名空间用于避免元素名称冲突,特别是在处理来自不同来源的 XML 数据时。在 JavaScript 中处理命名空间需要使用特定的方法,例如 getElementsByTagNameNS()getAttributeNS()

const xmlString = `
  text
`;

const parser = new DOMParser();
const xmlDoc = parser.parseFromString(xmlString, "text/xml");

const element = xmlDoc.getElementsByTagNameNS("http://example.com", "element")[0];
const attributeValue = element.getAttributeNS(null, "attribute"); // null 表示没有命名空间的属性
const textContent = element.textContent;

console.log(attributeValue); // 输出 "value"
console.log(textContent); // 输出 "text"

getElementsByTagNameNS() 方法接受命名空间 URI 和本地名称作为参数。getAttributeNS() 方法也类似,但第一个参数也可以是 null,表示获取没有命名空间的属性。

如何处理复杂的 XML 结构?

处理复杂的 XML 结构可能需要递归遍历 XML 树。你可以编写一个递归函数,该函数接受一个 XML 元素作为参数,并处理该元素的属性和子元素。

function processElement(element) {
  console.log("Element Name:", element.nodeName);
  for (let i = 0; i < element.attributes.length; i++) {
    const attribute = element.attributes[i];
    console.log("Attribute:", attribute.name, "=", attribute.value);
  }

  for (let i = 0; i < element.childNodes.length; i++) {
    const child = element.childNodes[i];
    if (child.nodeType === Node.ELEMENT_NODE) {
      processElement(child); // 递归调用
    } else if (child.nodeType === Node.TEXT_NODE) {
      console.log("Text Content:", child.textContent.trim());
    }
  }
}

const xmlString = `
  
    Some text
    More text
  
`;

const parser = new DOMParser();
const xmlDoc = parser.parseFromString(xmlString, "text/xml");

processElement(xmlDoc.documentElement); // 从根元素开始

这个例子展示了如何递归遍历 XML 树,并处理元素、属性和文本内容。根据你的具体需求,你可以修改 processElement() 函数来执行不同的操作。注意 trim() 方法用于去除文本内容中的空白字符。

如何处理 XML 解析中的错误?

XML 解析过程中可能会遇到各种错误,例如格式不正确、缺少必需的元素或属性等。为了确保你的代码能够正确处理这些错误,你需要进行适当的错误处理。

const xmlString = `
  
    Everyday Italian
    <author>Giada De Laurentiis</author>
    <year>2005</year>
    <price>30.00</price>
  </book>
</bookstore>`; // 缺少闭合标签

const parser = new DOMParser();
const xmlDoc = parser.parseFromString(xmlString, "text/xml");

const errorNode = xmlDoc.getElementsByTagName("parsererror")[0];

if (errorNode) {
  console.error("XML 解析错误:", errorNode.textContent);
} else {
  const title = xmlDoc.getElementsByTagName("title")[0].textContent;
  console.log(title);
}</pre><p>在这个例子中,XML 字符串缺少一个闭合标签,导致解析错误。通过检查 <code>xmlDoc.getElementsByTagName("parsererror")</code> 是否存在,我们可以判断是否发生了错误。如果存在错误,我们可以输出错误信息,而不是尝试访问不存在的元素。</p><p>以上就是《JS如何解析XML?3种常用方法超详细教程》的详细内容,更多关于JavaScript,jQuery,xml,XMLHttpRequest,DOMParser的资料请关注golang学习网公众号!</p>                </div>
                <div class="labsList">
                                        <a href="javascript:;"  title="JavaScript">JavaScript</a>
                                        <a href="javascript:;"  title="jQuery">jQuery</a>
                                        <a href="javascript:;"  title="xml">xml</a>
                                        <a href="javascript:;"  title="XMLHttpRequest">XMLHttpRequest</a>
                                        <a href="javascript:;"  title="DOMParser">DOMParser</a>
                                    </div>
                                <div class="cateBox">
                                        <div class="cateItem">
                        <a href="/article/236386.html" title="CSSborder属性不会用?这篇详细教程教你玩转边框样式" class="img_box">
                            <img src="/uploads/20250621/1750491846685662c6211c0.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="CSSborder属性不会用?这篇详细教程教你玩转边框样式">CSSborder属性不会用?这篇详细教程教你玩转边框样式                        </a>
                        <dl>
                            <dt class="lineOverflow"><a href="/article/236386.html"  title="CSSborder属性不会用?这篇详细教程教你玩转边框样式" class="aBlack">上一篇<i></i></a></dt>
                            <dd class="lineTwoOverflow">CSSborder属性不会用?这篇详细教程教你玩转边框样式</dd>
                        </dl>
                    </div>
                                        <div class="cateItem">
                        <a href="/article/236388.html"  title="uni-app开发避坑指南:超全规范+注意事项总结" class="img_box">
                            <img src="/uploads/20250621/17504919636856633b2ca97.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="uni-app开发避坑指南:超全规范+注意事项总结">
                        </a>
                        <dl>
                            <dt class="lineOverflow"><a href="/article/236388.html"  class="aBlack" title="uni-app开发避坑指南:超全规范+注意事项总结">下一篇<i></i></a></dt>
                            <dd class="lineTwoOverflow">uni-app开发避坑指南:超全规范+注意事项总结</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/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>
                                                       |  2天前  |  

                                                                        <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>
                                                       |  2天前  |  

                                                                        <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>
                                                       |  3天前  |  

                                                                        <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>
                                                       |  3天前  |  

                                                                        <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>
                                <li>
                    <div class="contBox">
                        <a href="/article/620012.html" class="img_box" title="前端长列表虚拟滚动实战:从可视区计算到滚动流畅">
                            <img src="/uploads/20260617/1781670928-frontend-virtual-list-before-after.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>
                                                       |  3天前  |  

                                                                        <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/39783_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/620012.html" class="aBlack" target="_blank" title="前端长列表虚拟滚动实战:从可视区计算到滚动流畅">前端长列表虚拟滚动实战:从可视区计算到滚动流畅</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>111浏览</span>
                                <span class="collectBtn user_collection" data-id="620012" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619999.html" class="img_box" title="前端轮询接口越打越多怎么办:从重复定时器到清理机制一步步排查">
                            <img src="/uploads/20260616/1781600013-frontend-polling-cleanup-solution.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>
                                                       |  4天前  |  

                                                                        <a href="/articletag/215_new_0_1.html" class="aLightGray" title="定时器">定时器</a> ·
                                                                          <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> ·
                                                                          <a href="/articletag/39721_new_0_1.html" class="aLightGray" title="性能排查">性能排查</a> ·
                                                                          <a href="/articletag/39918_new_0_1.html" class="aLightGray" title="接口请求">接口请求</a> ·
                                                                          <a href="/articletag/39934_new_0_1.html" class="aLightGray" title="轮询">轮询</a> ·
                                                                          <a href="/articletag/39935_new_0_1.html" class="aLightGray" title="setInterval">setInterval</a> ·
                                                                                   <a href="javascript:;" class="aLightGray" title="setInterval">setInterval</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="页面可见性">页面可见性</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="clearInterval">clearInterval</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/619999.html" class="aBlack" target="_blank" title="前端轮询接口越打越多怎么办:从重复定时器到清理机制一步步排查">前端轮询接口越打越多怎么办:从重复定时器到清理机制一步步排查</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>490浏览</span>
                                <span class="collectBtn user_collection" data-id="619999" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619992.html" class="img_box" title="前端表单重复提交治理完整流程:按钮锁定、请求去重和幂等 key">
                            <img src="/uploads/20260616/1781592762-form-submit-idempotent-key.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端表单重复提交治理完整流程:按钮锁定、请求去重和幂等 key">
                        </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>
                                                       |  4天前  |  

                                                                        <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> ·
                                                                          <a href="/articletag/39919_new_0_1.html" class="aLightGray" title="状态管理">状态管理</a> ·
                                                                          <a href="/articletag/39920_new_0_1.html" class="aLightGray" title="表单提交">表单提交</a> ·
                                                                          <a href="/articletag/39921_new_0_1.html" class="aLightGray" title="防重复提交">防重复提交</a> ·
                                                                          <a href="/articletag/39922_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="幂等key">幂等key</a>
                                                              </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619992.html" class="aBlack" target="_blank" title="前端表单重复提交治理完整流程:按钮锁定、请求去重和幂等 key">前端表单重复提交治理完整流程:按钮锁定、请求去重和幂等 key</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>253浏览</span>
                                <span class="collectBtn user_collection" data-id="619992" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619990.html" class="img_box" title="前端搜索结果倒退怎么办:AbortController 取消旧请求和序号兜底">
                            <img src="/uploads/20260616/1781590765-frontend-search-race-fix.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端搜索结果倒退怎么办:AbortController 取消旧请求和序号兜底">
                        </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>
                                                       |  4天前  |  

                                                                        <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> ·
                                                                          <a href="/articletag/39916_new_0_1.html" class="aLightGray" title="搜索框">搜索框</a> ·
                                                                          <a href="/articletag/39917_new_0_1.html" class="aLightGray" title="AbortController">AbortController</a> ·
                                                                          <a href="/articletag/39918_new_0_1.html" class="aLightGray" title="接口请求">接口请求</a> ·
                                                                          <a href="/articletag/39919_new_0_1.html" class="aLightGray" title="状态管理">状态管理</a> ·
                                                                                   <a href="javascript:;" class="aLightGray" title="Fetch">Fetch</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="AbortController">AbortController</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/619990.html" class="aBlack" target="_blank" title="前端搜索结果倒退怎么办:AbortController 取消旧请求和序号兜底">前端搜索结果倒退怎么办:AbortController 取消旧请求和序号兜底</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>295浏览</span>
                                <span class="collectBtn user_collection" data-id="619990" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619979.html" class="img_box" title="前端图片懒加载布局抖动治理完整流程:占位比例、按需加载和 CLS 复查">
                            <img src="/uploads/20260616/1781579104-frontend-lazy-cls-overview.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端图片懒加载布局抖动治理完整流程:占位比例、按需加载和 CLS 复查">
                        </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>
                                                       |  4天前  |  

                                                                        <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/34073_new_0_1.html" class="aLightGray" title="cls">cls</a> ·
                                                                          <a href="/articletag/39909_new_0_1.html" class="aLightGray" title="懒加载">懒加载</a> ·
                                                                          <a href="/articletag/39910_new_0_1.html" class="aLightGray" title="Core Web Vitals">Core Web Vitals</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="CLS">CLS</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="布局稳定">布局稳定</a>
                                                              </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619979.html" class="aBlack" target="_blank" title="前端图片懒加载布局抖动治理完整流程:占位比例、按需加载和 CLS 复查">前端图片懒加载布局抖动治理完整流程:占位比例、按需加载和 CLS 复查</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>128浏览</span>
                                <span class="collectBtn user_collection" data-id="619979" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619973.html" class="img_box" title="前端 WebSocket 断线重连完整流程:心跳检测、退避重试和消息补发">
                            <img src="/uploads/20260616/1781541472-frontend-websocket-message-queue.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端 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>
                                                       |  5天前  |  

                                                                        <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> ·
                                                                          <a href="/articletag/277_new_0_1.html" class="aLightGray" title="消息队列">消息队列</a> ·
                                                                          <a href="/articletag/1017_new_0_1.html" class="aLightGray" title="websocket">websocket</a> ·
                                                                          <a href="/articletag/39899_new_0_1.html" class="aLightGray" title="实时通信">实时通信</a> ·
                                                                          <a href="/articletag/39900_new_0_1.html" class="aLightGray" title="断线重连">断线重连</a> ·
                                                                                   <a href="javascript:;" 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="断线重连">断线重连</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="消息补发">消息补发</a>
                                                              </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619973.html" class="aBlack" target="_blank" title="前端 WebSocket 断线重连完整流程:心跳检测、退避重试和消息补发">前端 WebSocket 断线重连完整流程:心跳检测、退避重试和消息补发</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>365浏览</span>
                                <span class="collectBtn user_collection" data-id="619973" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619962.html" class="img_box" title="前端弹窗层级治理工作流:从 z-index 混乱到 Portal 容器规范">
                            <img src="/uploads/20260615/1781506972-modal-layer-workflow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端弹窗层级治理工作流:从 z-index 混乱到 Portal 容器规范">
                        </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>
                                                       |  5天前  |  

                                                                        <a href="/articletag/228_new_0_1.html" class="aLightGray" title="工程化">工程化</a> ·
                                                                          <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> ·
                                                                          <a href="/articletag/4701_new_0_1.html" class="aLightGray" title="javascript">javascript</a> ·
                                                                          <a href="/articletag/4729_new_0_1.html" class="aLightGray" title="css">css</a> ·
                                                                          <a href="/articletag/39876_new_0_1.html" class="aLightGray" title="弹窗">弹窗</a> ·
                                                                                   <a href="javascript:;" class="aLightGray" title="前端">前端</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="z-index">z-index</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="遮罩层">遮罩层</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="stacking context">stacking context</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="Portal">Portal</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="弹窗层级">弹窗层级</a>
                                                              </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619962.html" class="aBlack" target="_blank" title="前端弹窗层级治理工作流:从 z-index 混乱到 Portal 容器规范">前端弹窗层级治理工作流:从 z-index 混乱到 Portal 容器规范</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>350浏览</span>
                                <span class="collectBtn user_collection" data-id="619962" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619961.html" class="img_box" title="前端筛选条件刷新后丢失怎么办:从内存状态到 URL 参数一步步排查">
                            <img src="/uploads/20260615/1781505934-filter-refresh-lost.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端筛选条件刷新后丢失怎么办:从内存状态到 URL 参数一步步排查">
                        </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>
                                                       |  5天前  |  

                                                                        <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> ·
                                                                          <a href="/articletag/4701_new_0_1.html" class="aLightGray" title="javascript">javascript</a> ·
                                                                          <a href="/articletag/39873_new_0_1.html" class="aLightGray" title="URL参数">URL参数</a> ·
                                                                          <a href="/articletag/39874_new_0_1.html" class="aLightGray" title="列表筛选">列表筛选</a> ·
                                                                          <a href="/articletag/39875_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="history.replaceState">history.replaceState</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="URLSearchParams">URLSearchParams</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="刷新还原">刷新还原</a>
                                                              </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619961.html" class="aBlack" target="_blank" title="前端筛选条件刷新后丢失怎么办:从内存状态到 URL 参数一步步排查">前端筛选条件刷新后丢失怎么办:从内存状态到 URL 参数一步步排查</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>348浏览</span>
                                <span class="collectBtn user_collection" data-id="619961" 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">1186次使用</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">1138次使用</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">1074次使用</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">1260次使用</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">1250次使用</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/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>
                            </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/236387.html"/>
                <input type="hidden" name="__token__" value="91b1353e08348416d992ecee6e88ca69" />                <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/236387.html"/>
                <input type="hidden" name="__token__" value="91b1353e08348416d992ecee6e88ca69" />                <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>