发布 f `@xmldom/xmldom`
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《发布 f `@xmldom/xmldom`》,聊聊,我们一起来看看吧!
语境
xmldom 是一个 javascript ponyfill,用于向其他运行时提供现代浏览器中存在的以下 api:
- 将 xml 字符串转换为 dom 树
new domparser().parsefromstring(xml, mimetype) => document
- 创建、访问和修改 dom 树
new domimplementation().createdocument(...) => document
- 将 dom 树序列化回 xml 字符串
new xmlserializer().serializetostring(node) => string
来源:xmldom 自述文件
历史
自从我在 2020 年 6 月开始为分叉的 xmldom 库做出贡献以来,已经发布了 40 个版本。
这是一个非常有趣且具有挑战性的项目,并且很可能会在相当长的一段时间内保持这种状态。
据 github 称,自分叉以来已有 50 多人为其做出了贡献。
再次感谢所有贡献者。
这并不包括所有设法从原始无作用域 xmldom 包迁移到有作用域 @xmldom/xmldom 包版本 0.7.0 以获得所有安全修复程序的人。
作为 lts 标签发布的最新版本是 0.7.13。
最后一个具有重大更改的版本是 0.8.0,发布于 2021 年 12 月 22 日,大约 3 年前。
最新发布的版本是0.8.10。
0.9.0 (2024-08-29)
但是我今天要讲的是自 2022 年 10 月以来在 next 标签下发布的所有内容。
我对这些变化感到非常兴奋,因为它们为未来潜在的变化提供了明确的基础。
tldr:与规范更加一致,差异尽可能明确。
1. 强制mimetype交还控制权
使实现变得复杂的一个方面是解析 xml 与 html 的规则不同。
xmldom(在某种程度上)从一开始就“支持”这两种风格。甚至根本不需要传递 mimetype:应用什么规则是根据当前正在解析的 xml 字符串/节点的当前默认命名空间决定的。
这以 0.9.0 结束:从现在开始,domparser.parsefromstring(xml, mimetype) 中的 mimetype 是强制性的,并且是唯一被检查以决定是否应用 xml 或 html 规则的东西。巴斯塔。
该信息会保留在生成的文档(新类型属性)中,因此在序列化它时,会再次应用正确的规则。
这是一个巨大的(并且可能是破坏性的)变化,但我真的很高兴它已经准备好了,因为它使大量相关的错误修复变得可能/更容易实现,并且还降低了 api 和实现的复杂性。
此外,它现在只接受指定的 mime 类型,并在任何其他情况下抛出 typeerror。
严格性和错误处理
我个人对原生浏览器 api 的错误处理感到困惑的是,它总是返回一个 document,如果出现问题,parsererror 节点将是主体的第一个子节点:
由于错误处理在 xmldom 中从来没有以这种方式工作,但现有的错误处理非常复杂、混乱且文档记录很差,0.9.0 对其进行了简化,现在对解析过程中发生的任何潜在错误具有(更加)一致的行为:
它会抛出一个 parseerror ?,例如有下列情况之一的:
- 在以前的版本中,对于某些格式不正确的 xml 字符串,返回的 document 可能没有 documentelement,这很可能会导致后面的代码出现 typeerrors。
- 几个格式不正确的 xml 字符串现在将正确报告为 fatalerror,现在总是阻止任何进一步的处理。
- 一些以前未报告为错误或仅报告为警告的事情现在也报告为 fatalerror
仍然有一些情况会被报告为警告(尤其是在解析 html 时)或错误,但不会阻止数据的处理,但是新的错误处理可以很容易地决定代码的严格程度需要使用 xmldom。
可以传递给 domparser 构造函数的(不符合规范的)选项称为 onerror。
它需要一个具有以下签名的函数:
function onerror(level:errorlevel, message:string, context: domhandler):void;
- errorlevel 是警告、错误或 fatalerror
- xmldom 已经为两个最常见的用例提供了实现:
- onerrorstopparsing 也会针对所有错误级别问题抛出 parseerror
- onwarningstopparsing 也会针对所有错误级别问题抛出 parseerror
建议应用其中一个来在出现任何意外的第一个信号时停止处理 xml:
// prevent parsing of XML that has `error`s new DOMParser({onError: onErrorStopParsing}).parseFromString(...) // prevent parsing of XML that has `warning`s new DOMParser({onError: onWarningStopParsing}).parseFromString(...)
comparedocumentposition,扩展 html 实体,null 而不是 undefined,...
原始 xmldom 存储库的另一个分支通过将 html 实体扩展到完整集(在 0.8.x 中也可用)并移植comparedocumentposition api 的实现,使其重新回到我们的存储库中。谢谢你,欢迎@zorkow
在此过程中,xmldom 迄今为止返回未定义而不是 null 的几个地方已得到修复,以符合规范。
而且我发现前作者似乎更喜欢在很多地方从列表的末尾开始迭代,属性在多个地方以相反的顺序处理,现在已修复。
removechild api 的实现发生了很大的变化,以符合规范并在应该抛出 domexception 的时候。
并且修复了 3 个相关错误,明确说明了 xmldom 的未来方向:
仅当适当严格的 xml 解析不受其影响时,才会提供对宽松 html 解析规则的支持。
以前(已损坏的)html 中自动自关闭标签的“支持”已经消失了。
coctype内部子集
最近,@shunkica 投入了大量的时间来解决以前处理 !doctype 内部子集部分时出现的大量问题。
它现在被保留为文档文档类型的internalsubset属性的一部分,并且现在可以正确检测到许多错误的文档类型声明并报告为 fatalerror。
同时感谢@kboshold 在该领域的最新错误修复。
在此过程中,我们创建了一个包含相关语法正则表达式的新模块,正确性检查基于这些模块,并且测试正确地覆盖了它们。
xmldom 的目标不是成为验证解析器,但这是支持那些带有更复杂 dtd 的文档的重要一步。
还有更多
到目前为止,开发是使用 node v10 完成的,因为这也是 xmldom 当前支持的最低版本。作为即将推出的版本工作的一部分,我决定切换到 v18 进行开发,因为越来越多的 devdependency 也使这成为最低要求。从该版本开始,这将是目前新的最低运行时版本。
我发起了一项公众投票/讨论,询问人们他们需要支持哪个版本的 node 或其他运行时。
如果没有反馈表明有什么不同,下一个重大版本很可能会放弃对某些旧 node 版本的支持。
一路走来,很多 api 都收到了具有正确类型的 jsdoc 注释。
谢谢
感谢您花时间阅读所有这些。
这些变化相当大,我很高兴能够交付这些变化。
我希望你和我一样兴奋:)
如果您需要更多详细信息,可以查看非常详细的变更日志,或者前往存储库并加入或开始讨论或提出问题。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《发布 f `@xmldom/xmldom`》文章吧,也可关注golang学习网公众号了解相关技术文章。

- 上一篇
- Win10怎么查看网卡属性_Win10查看网卡属性方法介绍

- 下一篇
- 国泰航空发现 15 架空客 A350 飞机引擎零部件故障,预计 9 月 7 日前全部恢复运营
-
- 文章 · 前端 | 1小时前 | 分页导航 content属性 counter-increment counter-reset CSScounter
- CSS分页数字样式与counter应用详解
- 104浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- ScrollControls触摸控制怎么实现
- 400浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- HTML5WebStorage详解:替代Cookie的新选择
- 230浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- JavaScript闭包实现状态保持技巧
- 385浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- async/await让异步代码更简洁易读
- 319浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- HTML常见错误与解决方法
- 457浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- JS引擎与DOM协作解析:DOM更新机制详解
- 425浏览 收藏
-
- 文章 · 前端 | 1小时前 | 性能优化 JavaScript动画 CSS3动画 动画触发 HTML动画
- HTML动画实现方法及技巧
- 239浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- K6函数会等待异步方法完成吗?
- 207浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- CSS滚动偏移技巧:scroll-margin定位方法
- 157浏览 收藏
-
- 文章 · 前端 | 2小时前 | html 属性 表单 日期选择器 inputtype="date"
- HTML日期选择器怎么用
- 152浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 175次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 174次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 176次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 180次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 194次使用
-
- 优化用户界面体验的秘密武器:CSS开发项目经验大揭秘
- 2023-11-03 501浏览
-
- 使用微信小程序实现图片轮播特效
- 2023-11-21 501浏览
-
- 解析sessionStorage的存储能力与限制
- 2024-01-11 501浏览
-
- 探索冒泡活动对于团队合作的推动力
- 2024-01-13 501浏览
-
- UI设计中为何选择绝对定位的智慧之道
- 2024-02-03 501浏览