XML 解析器,支持布尔属性、自结束标签元素、保持元素属性。
npm i xmlparsing
import { parser, generator } from 'xmlparsing';
// parse
const xmlDocument = parser.parse('<hello class="red"></hello>');
// firstChild
const helloElement = xmlDocument.firstChild;
// tagName
console.info(helloElement.tagName); // hello
// getAttribute
console.info(helloElement.getAttribute('class')); // red;
helloElement.setAttribute('class', 'green');
// generate
generator.generate(xmlDocument); // <hello class="green"></hello>
- Document
- Element
- Fragment
- Text
- Comment
- Cdata
类型:string
节点类型:document、element、fragment、text、comment、cdata 类型
类型:string | null
节点值:Text 节点、Comment 节点、Cdata 节点的文本内容,其他节点的 nodeValue 为 null
所有子节点数组
父节点
前一个兄弟节点
前一个兄弟元素节点
后一个兄弟节点
后一个兄弟元素节点
第一个子节点
最后一个子节点
节点字符串文本
所有子节点的字符串文本
说明:获取属性值
参数:attributeName 属性名
// <div class="hello" />
node.getAttribute('class'); // 'hello'
说明: 设置属性值
参数: attributeName 属性名, newValue 属性值
// <div class="hello" />
node.getAttribute('class', 'green');
node.getAttribute('id', 'abc'); // <div class="green" id="abc"></div>
说明: 删除节点属性
参数: attributeName
// <div class="hello" />
node.removeAttribute('class');
node.getAttribute('id', 'abc'); // <div></div>
说明: 判断节点是否有纯在的属性
参数: attributeName
// <div class="hello" />
node.removeAttribute('class');
node.getAttribute('id', 'abc'); // <div></div>
说明: 添加子节点
参数: childNode
// <div class="hello" />
const newNode = node.createElement('xyz');
node.appendChild(newNode); // <div class="hello"><xyz></xyz></div>
说明: 在参考节点前插入节点
参数: newNode 新节点,referenceNode 参考相关节点
// <div><x /></div>
const newNode = node.createElement('y');
node.insertBefore(newNode, node.firstChild); // <div><y></y><x /></div>
说明: 在参考节点后插入节点
参数: newNode 新节点,referenceNode 参考相关节点
// <div><x /></div>
const newNode = node.createElement('y');
node.insertAfter(newNode, node.firstChild); // <div><x /><y></y></div>
说明:在节点前添加新节点
参数: newNode
// <div></div>
const newNode = node.createElement('y');
node.before(newNode); // <y></y><div></div>
说明:在节点后添加新节点
参数: newNode
// <div></div>
const newNode = node.createElement('y');
node.after(newNode); // <div></div><y></y>
说明:删除子节点
参数: newNode
// <div><a /><b /></div>
const newNode = node.removeChild(node.firstChild); <div><b /></div>
说明:用新节点替换节点本身
说明:删除节点本身
说明:清空节点所有子节点
说明:克隆节点本身
说明:返回节点字符串序列
说明:返回所有指定节点名称的所有子节点
说明:创建新元素节点
说明:创建注释节点
说明:创建文本节点
说明:创建片段节点