JavaScript 中 xml 的解析(jsoup 解析器),一线互联网大厂面试真题系统收录


一、概述

====

xml 的解析就是操作 xml 文档,将文档内容读取到内存中,解析的方法两种

  1. dom:将标记语言文档一次性加载到内存,在内存中形成一颗 dom 树

  2. sax:逐行解析

二、dom 和 sax 解析对比

================

dom 解析:

  • 根据 xml 的层级结构在内存中分配一个树形结构,把 xml 的标签,属性和文本都封装成对象

  • 优点:很方便实现增、删、改操作

  • 缺点:消耗内存,会造成内存溢出

sax 解析:

  • 采用事件驱动,边读边解析

  • 从上到下,一行一行的解析,解析到某个对象就返回对象名称

  • 优点:不占内存,方便实现查询操作

  • 缺点:只能读取,不能实现增、删、改操作

三、解析器

=====

不同的公司和组织提供了针对 dom 和 sax 方式的解析器,都是通过 api 方式提供的,主要有:

  • sun 公司提供的针对 dom 和 sax 解析器:Jaxp

  • dom4j 组织提供的针对 dom 和 sax 解析器:dom4j(开发中用的最多)

  • jdom 组织提供的针对 dom 和sax 解析器:Jdom

  • Java的HTML解析器,可以直接解析URL地址、HTML 文本内容:Jsoup

四、Jsoup 解析器

===========

1、导入 jar 包


导入 jsoup-1.12.1.jar 包

链接:https://pan.baidu.com/s/1wz8NKy2xgqTV5lzc4CbaQQ

提取码:rwwo

2、获取 Document 对象


  • parse()方法:解析 HTML 或 xml 文档,返回 Document 对象

  • parse(File in,String charsetName):解析 xml 或 HTML 文件

  • parse(String html):解析 xml 或 HTML 字符串

  • parse(URL url,int timeoutMillis):通过网络路径获取指定的 HTML 或 xml 文档对象

3、获取对应的标签 Element 对象


  • getElementById(String id):根据id属性值获取唯一的element对象

  • getElementByTag(String tagName):根据标签名称获取元素对象集合

  • getElementByAttribute(String key):根据属性名称获取元素对象集合

  • getElementByAttributeValue(String key,String value):根据对应的属性名称和属性值获取元素对象集合

4、获取数据


public static void main(String[] args) throws IOException {

//1.获取Document对象

String path = jsoup.class.getClassLoader().getResource(“person.xml”).getPath();

Document document = Jsoup.parse(new File(path),“utf-8”);

//2.获取元素Element对象

Elements elements = document.getElementsByTag(“name”);

System.out.println(elements);

System.out.println(“******************”);

//3.获取第一个name的Element对象

Element element = elements.get(0);

System.out.println(element.text());

System.out.println(“******************”);

//4.获取属性名为pid的元素对象

Elements elements1 = document.getElementsByAttribute(“id”);

System.out.println(elements1);

System.out.println(“******************”);

//5.获取number属性值为15450132的元素对象

Elements elements2 = document.getElementsByAttributeValue(“number”,“15450132”);

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

最后

全网独播-价值千万金融项目前端架构实战

从两道网易面试题-分析JavaScript底层机制

RESTful架构在Nodejs下的最佳实践

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

一线互联网企业如何初始化项目-做一个自己的vue-cli

思维无价,看我用Nodejs实现MVC

代码优雅的秘诀-用观察者模式深度解耦模块

前端高级实战,如何封装属于自己的JS库

VUE组件库级组件封装-高复用弹窗组件


jA4ZThlZjdjZjRhZWRjZl9oZC5qcGc?x-oss-process=image/format,png)

VUE组件库级组件封装-高复用弹窗组件

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值