登录
首页 >  文章 >  前端

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

时间:2025-06-21 15:45:18 242浏览 收藏

想知道**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:;"  class="aLightGray" title="JavaScript">JavaScript</a>
                        <a href="javascript:;"  class="aLightGray" title="jQuery">jQuery</a>
                        <a href="javascript:;"  class="aLightGray" title="xml">xml</a>
                        <a href="javascript:;"  class="aLightGray" title="XMLHttpRequest">XMLHttpRequest</a>
                        <a href="javascript:;"  class="aLightGray" title="DOMParser">DOMParser</a>
                    </div>
          </div>

         <!-- 最新阅读 -->
     <div class="contBoxNor">
      <div class="contTit">
        <div class="tit">相关阅读</div>
        <a href="/articlelist.html" class="more">更多></a>
      </div>
      <ul class="latestReadList">
                <li>
          <div class="info">
                                  <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                          |  1年前  |  
                                       <a href="javascript:;" class="aLightGray" title="CSS">CSS</a>
                                                 <a href="javascript:;" class="aLightGray" title="优化">优化</a>
                                                 <a href="javascript:;" class="aLightGray" title="体验">体验</a>
                      </div>
          <div class="tit lineOverflow"><a href="/article/72840.html"  title="优化用户界面体验的秘密武器:CSS开发项目经验大揭秘" class="aBlack">优化用户界面体验的秘密武器:CSS开发项目经验大揭秘</a></div>
          <div class="opt">
            <span><i class="view"></i>501</span>
            <span class="collectBtn user_collection" data-id="72840" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
          </div>
        </li>
                <li>
          <div class="info">
                                  <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                          |  1年前  |  
                                       <a href="javascript:;" class="aLightGray" title="图片轮播">图片轮播</a>
                                                 <a href="javascript:;" class="aLightGray" title="微信小程序">微信小程序</a>
                                                 <a href="javascript:;" class="aLightGray" title="特效">特效</a>
                      </div>
          <div class="tit lineOverflow"><a href="/article/76259.html"  title="使用微信小程序实现图片轮播特效" class="aBlack">使用微信小程序实现图片轮播特效</a></div>
          <div class="opt">
            <span><i class="view"></i>501</span>
            <span class="collectBtn user_collection" data-id="76259" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
          </div>
        </li>
                <li>
          <div class="info">
                                  <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                          |  1年前  |  
                                       <a href="javascript:;" class="aLightGray" title="sessionStorage">sessionStorage</a>
                                                 <a href="javascript:;" class="aLightGray" title="存储能力">存储能力</a>
                                                 <a href="javascript:;" class="aLightGray" title="限制解析">限制解析</a>
                      </div>
          <div class="tit lineOverflow"><a href="/article/83771.html"  title="解析sessionStorage的存储能力与限制" class="aBlack">解析sessionStorage的存储能力与限制</a></div>
          <div class="opt">
            <span><i class="view"></i>501</span>
            <span class="collectBtn user_collection" data-id="83771" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
          </div>
        </li>
                <li>
          <div class="info">
                                  <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                          |  1年前  |  
                                       <a href="javascript:;" class="aLightGray" title="团队合作">团队合作</a>
                                                 <a href="javascript:;" class="aLightGray" title="冒泡事件">冒泡事件</a>
                                                 <a href="javascript:;" class="aLightGray" title="促进作用">促进作用</a>
                      </div>
          <div class="tit lineOverflow"><a href="/article/85057.html"  title="探索冒泡活动对于团队合作的推动力" class="aBlack">探索冒泡活动对于团队合作的推动力</a></div>
          <div class="opt">
            <span><i class="view"></i>501</span>
            <span class="collectBtn user_collection" data-id="85057" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
          </div>
        </li>
                <li>
          <div class="info">
                                  <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                          |  1年前  |  
            </div>
          <div class="tit lineOverflow"><a href="/article/91359.html"  title="UI设计中为何选择绝对定位的智慧之道" class="aBlack">UI设计中为何选择绝对定位的智慧之道</a></div>
          <div class="opt">
            <span><i class="view"></i>501</span>
            <span class="collectBtn user_collection" data-id="91359" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
          </div>
        </li>
              </ul>
    </div>
         <!-- 最新阅读 -->
      <div class="contBoxNor">
          <div class="contTit">
              <div class="tit">最新阅读</div>
              <a href="/articlelist.html" class="more">更多></a>
          </div>
          <ul class="latestReadList">
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  23秒前  |  
                                            <a href="javascript:;" class="aLightGray" title="html">html</a>
                                            <a href="javascript:;" class="aLightGray" title="SEO">SEO</a>
                                            <a href="javascript:;" class="aLightGray" title="字符编码">字符编码</a>
                                            <a href="javascript:;" class="aLightGray" title="视口">视口</a>
                                            <a href="javascript:;" class="aLightGray" title="meta标签">meta标签</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236824.html"  title="搞懂meta标签就靠这篇!meta标签全面解析" class="aBlack">搞懂meta标签就靠这篇!meta标签全面解析</a></div>
                  <div class="opt">
                      <span><i class="view"></i>321</span>
                      <span class="collectBtn user_collection" data-id="236824" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  2分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="异步编程">异步编程</a>
                                            <a href="javascript:;" class="aLightGray" title="Promise">Promise</a>
                                            <a href="javascript:;" class="aLightGray" title="async/await">async/await</a>
                                            <a href="javascript:;" class="aLightGray" title="Promise.all">Promise.all</a>
                                            <a href="javascript:;" class="aLightGray" title="Promise.race">Promise.race</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236822.html"  title="JS进阶必备!手把手教你搞定Promise链式调用" class="aBlack">JS进阶必备!手把手教你搞定Promise链式调用</a></div>
                  <div class="opt">
                      <span><i class="view"></i>101</span>
                      <span class="collectBtn user_collection" data-id="236822" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  2分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="响应式布局">响应式布局</a>
                                            <a href="javascript:;" class="aLightGray" title="网格布局">网格布局</a>
                                            <a href="javascript:;" class="aLightGray" title="CSSGrid">CSSGrid</a>
                                            <a href="javascript:;" class="aLightGray" title="display:grid">display:grid</a>
                                            <a href="javascript:;" class="aLightGray" title="grid-template">grid-template</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236821.html"  title="CSS网格布局超简单教程,零基础小白一看就会!" class="aBlack">CSS网格布局超简单教程,零基础小白一看就会!</a></div>
                  <div class="opt">
                      <span><i class="view"></i>279</span>
                      <span class="collectBtn user_collection" data-id="236821" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  4分钟前  |  
                                            <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="Promise">Promise</a>
                                            <a href="javascript:;" class="aLightGray" title="Array">Array</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236819.html"  title="JS多条件并行判断超简单写法,效率爆表!" class="aBlack">JS多条件并行判断超简单写法,效率爆表!</a></div>
                  <div class="opt">
                      <span><i class="view"></i>430</span>
                      <span class="collectBtn user_collection" data-id="236819" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  6分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="html">html</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="内嵌JS代码">内嵌JS代码</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236815.html"  title="手把手教学!这样在HTML里嵌JS代码才正确~" class="aBlack">手把手教学!这样在HTML里嵌JS代码才正确~</a></div>
                  <div class="opt">
                      <span><i class="view"></i>196</span>
                      <span class="collectBtn user_collection" data-id="236815" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  14分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="html">html</a>
                                            <a href="javascript:;" class="aLightGray" title="iframe">iframe</a>
                                            <a href="javascript:;" class="aLightGray" title="加载速度">加载速度</a>
                                            <a href="javascript:;" class="aLightGray" title="属性">属性</a>
                                            <a href="javascript:;" class="aLightGray" title="替代方案">替代方案</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236806.html"  title="html如何嵌入iframe?iframe尺寸和属性设置全解" class="aBlack">html如何嵌入iframe?iframe尺寸和属性设置全解</a></div>
                  <div class="opt">
                      <span><i class="view"></i>114</span>
                      <span class="collectBtn user_collection" data-id="236806" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  15分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="html">html</a>
                                            <a href="javascript:;" class="aLightGray" title="样式">样式</a>
                                            <a href="javascript:;" class="aLightGray" title="列表">列表</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236804.html"  title="HTML中ul和ol傻傻分不清?无序列表&有序列表实操教学" class="aBlack">HTML中ul和ol傻傻分不清?无序列表&有序列表实操教学</a></div>
                  <div class="opt">
                      <span><i class="view"></i>499</span>
                      <span class="collectBtn user_collection" data-id="236804" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  16分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="html">html</a>
                                            <a href="javascript:;" class="aLightGray" title="CSS">CSS</a>
                                            <a href="javascript:;" class="aLightGray" title="JavaScript">JavaScript</a>
                                            <a href="javascript:;" class="aLightGray" title="星级评分">星级评分</a>
                                            <a href="javascript:;" class="aLightGray" title="用户交互">用户交互</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236803.html"  title="手把手教你用HTML实现超酷星级评分功能!" class="aBlack">手把手教你用HTML实现超酷星级评分功能!</a></div>
                  <div class="opt">
                      <span><i class="view"></i>125</span>
                      <span class="collectBtn user_collection" data-id="236803" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  18分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="权限控制">权限控制</a>
                                            <a href="javascript:;" class="aLightGray" title="路由守卫">路由守卫</a>
                                            <a href="javascript:;" class="aLightGray" title="SPA">SPA</a>
                                            <a href="javascript:;" class="aLightGray" title="前端路由拦截">前端路由拦截</a>
                                            <a href="javascript:;" class="aLightGray" title="异步权限验证">异步权限验证</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236800.html"  title="手把手教你用JS实现前端路由拦截,轻松搞定页面权限(附5种方案)" class="aBlack">手把手教你用JS实现前端路由拦截,轻松搞定页面权限(附5种方案)</a></div>
                  <div class="opt">
                      <span><i class="view"></i>178</span>
                      <span class="collectBtn user_collection" data-id="236800" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  22分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="html">html</a>
                                            <a href="javascript:;" class="aLightGray" title="CSS">CSS</a>
                                            <a href="javascript:;" class="aLightGray" title="页面布局">页面布局</a>
                                            <a href="javascript:;" class="aLightGray" title="语义化标签">语义化标签</a>
                                            <a href="javascript:;" class="aLightGray" title="<div>标签"><div>标签</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236796.html"  title="HTML中的div标签到底啥意思?手把手教你玩转div标签" class="aBlack">HTML中的div标签到底啥意思?手把手教你玩转div标签</a></div>
                  <div class="opt">
                      <span><i class="view"></i>476</span>
                      <span class="collectBtn user_collection" data-id="236796" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  33分钟前  |  
                                            <a href="javascript:;" class="aLightGray" title="网页设计">网页设计</a>
                                            <a href="javascript:;" class="aLightGray" title="::after">::after</a>
                                            <a href="javascript:;" class="aLightGray" title="CSS伪元素">CSS伪元素</a>
                                            <a href="javascript:;" class="aLightGray" title="content属性">content属性</a>
                                            <a href="javascript:;" class="aLightGray" title="::before">::before</a>
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236782.html"  title="CSS伪元素不会用?手把手教你快速掌握伪元素技巧" class="aBlack">CSS伪元素不会用?手把手教你快速掌握伪元素技巧</a></div>
                  <div class="opt">
                      <span><i class="view"></i>191</span>
                      <span class="collectBtn user_collection" data-id="236782" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                            <li>
                  <div class="info">
                                            <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                              |  39分钟前  |  
                      </div>
                  <div class="tit lineOverflow"><a href="/article/236775.html"  title="JS策略模式?简单又强大的代码优化神器!" class="aBlack">JS策略模式?简单又强大的代码优化神器!</a></div>
                  <div class="opt">
                      <span><i class="view"></i>241</span>
                      <span class="collectBtn user_collection" data-id="236775" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                  </div>
              </li>
                        </ul>
      </div>
    <!-- 课程推荐 -->
    <div class="contBoxNor">
      <div class="contTit">
        <div class="tit">课程推荐</div>
        <a href="/courselist.html" class="more">更多></a>
      </div>
      <ul class="classRecomList">
                <li>
          <a href="/course/9.html" title="前端进阶之JavaScript设计模式" class="img_box">
            <img src="/uploads/20221222/52fd0f23a454c71029c2c72d206ed815.jpg" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="前端进阶之JavaScript设计模式">
                      </a>
          <dl>
            <dt class="lineOverflow">
              前端进阶之JavaScript设计模式            </dt>
            <dd class="cont1 lineOverflow">设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。</dd>
            <dd class="cont2">
              <a href="/course/9.html" title="前端进阶之JavaScript设计模式" class="toStudy">立即学习</a>
              <span>542次学习</span>
            </dd>
          </dl>
        </li>
                <li>
          <a href="/course/2.html" title="GO语言核心编程课程" class="img_box">
            <img src="/uploads/20221221/634ad7404159bfefc6a54a564d437b5f.png" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="GO语言核心编程课程">
                      </a>
          <dl>
            <dt class="lineOverflow">
              GO语言核心编程课程            </dt>
            <dd class="cont1 lineOverflow">本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。</dd>
            <dd class="cont2">
              <a href="/course/2.html" title="GO语言核心编程课程" class="toStudy">立即学习</a>
              <span>508次学习</span>
            </dd>
          </dl>
        </li>
                <li>
          <a href="/course/74.html" title="简单聊聊mysql8与网络通信" class="img_box">
            <img src="/uploads/20240103/bad35fe14edbd214bee16f88343ac57c.png" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="简单聊聊mysql8与网络通信">
                      </a>
          <dl>
            <dt class="lineOverflow">
              简单聊聊mysql8与网络通信            </dt>
            <dd class="cont1 lineOverflow">如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让</dd>
            <dd class="cont2">
              <a href="/course/74.html" title="简单聊聊mysql8与网络通信" class="toStudy">立即学习</a>
              <span>497次学习</span>
            </dd>
          </dl>
        </li>
                <li>
          <a href="/course/57.html" title="JavaScript正则表达式基础与实战" class="img_box">
            <img src="/uploads/20221226/bbe4083bb3cb0dd135fb02c31c3785fb.jpg" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="JavaScript正则表达式基础与实战">
                      </a>
          <dl>
            <dt class="lineOverflow">
              JavaScript正则表达式基础与实战            </dt>
            <dd class="cont1 lineOverflow">在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。</dd>
            <dd class="cont2">
              <a href="/course/57.html" title="JavaScript正则表达式基础与实战" class="toStudy">立即学习</a>
              <span>487次学习</span>
            </dd>
          </dl>
        </li>
                <li>
          <a href="/course/28.html" title="从零制作响应式网站—Grid布局" class="img_box">
            <img src="/uploads/20221223/ac110f88206daeab6c0cf38ebf5fe9ed.jpg" onerror="this.onerror='';this.src='/assets/images/moren/morentu.png'" alt="从零制作响应式网站—Grid布局">
                      </a>
          <dl>
            <dt class="lineOverflow">
              从零制作响应式网站—Grid布局            </dt>
            <dd class="cont1 lineOverflow">本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。</dd>
            <dd class="cont2">
              <a href="/course/28.html" title="从零制作响应式网站—Grid布局" class="toStudy">立即学习</a>
              <span>484次学习</span>
            </dd>
          </dl>
        </li>
              </ul>
    </div>
        </div>
  <!-- footer -->
  <link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet">
<div class="footer">
    <ul>
      <li  ><a href="/" class="aLightGray"><em class="material-icons">home</em><span>首页</span></a></li>
      <li  class="curr"><a href="/articlelist.html" class="aLightGray"><em class="material-icons">menu_book</em><span>阅读</span></a></li>
      <li  ><a href="/courselist.html" class="aLightGray"><em class="material-icons">school</em><span>课程</span></a></li>
      <li  ><a href="/ai.html" class="aLightGray"><em class="material-icons">smart_toy</em><span>AI助手</span></a></li>
      <li ><a href="/user.html" class="aLightGray"><em class="material-icons">person</em><span>我的</span></a></li>
    </ul>
  </div>
  <script src="/assets/js/require.js" data-main="/assets/js/require-frontend.js?v=1671101972"></script>
<script>
    var _hmt = _hmt || [];
    (function() {
        var hm = document.createElement("script");
        hm.src = "https://hm.baidu.com/hm.js?3dc5666f6478c7bf39cd5c91e597423d";
        var s = document.getElementsByTagName("script")[0];
        s.parentNode.insertBefore(hm, s);
    })();
</script>
</body>
</html>