visitHast()
Berjalan dan mentransformasi pohon HAST menggunakan fungsi visitor.
import { visitHast } from "@unifast/core";Signature
function visitHast(node: HastNode, visitor: (node: HastNode) => HastNode | void): HastNodeParameter
node
| Properti | Tipe | Default | Deskripsi |
|---|---|---|---|
type | string | — | Tipe node ("root", "element", "text", dll.) |
children | HastNode[] | — | Node anak (untuk tipe "root" dan "element") |
visitor
| Properti | Tipe | Default | Deskripsi |
|---|---|---|---|
visitor | (node: HastNode) => HastNode | void | — | Sebuah fungsi yang dipanggil untuk setiap node; kembalikan sebuah node untuk menggantikan yang asli, atau void untuk membiarkannya |
Return
HastNode — Sebuah pohon baru dengan transformasi yang diterapkan oleh fungsi visitor.
Penggunaan
import { visitHast } from "@unifast/core";
import type { HastNode, HastRoot } from "@unifast/core";
const tree: HastRoot = {
type: "root",
children: [
{
type: "element",
tagName: "p",
properties: {},
children: [{ type: "text", value: "Hello world" }],
},
],
};
const result = visitHast(tree, (node) => {
if (node.type === "text") {
return { type: "text", value: node.value.toUpperCase() };
}
});
console.log(result);
// Tree with text "HELLO WORLD"Contoh
Menambahkan class ke semua paragraf
import { visitHast } from "@unifast/core";
import type { HastRoot } from "@unifast/core";
const tree: HastRoot = {
type: "root",
children: [
{
type: "element",
tagName: "p",
properties: {},
children: [{ type: "text", value: "First paragraph." }],
},
{
type: "element",
tagName: "p",
properties: {},
children: [{ type: "text", value: "Second paragraph." }],
},
],
};
const result = visitHast(tree, (node) => {
if (node.type === "element" && node.tagName === "p") {
return {
...node,
properties: { ...node.properties, className: ["prose"] },
};
}
});
// Both <p> elements now have className: ["prose"]Menghapus semua gambar
import { visitHast } from "@unifast/core";
import type { HastRoot } from "@unifast/core";
const tree: HastRoot = {
type: "root",
children: [
{
type: "element",
tagName: "p",
properties: {},
children: [
{ type: "text", value: "See the photo: " },
{
type: "element",
tagName: "img",
properties: { src: "photo.jpg", alt: "A photo" },
children: [],
},
],
},
],
};
const result = visitHast(tree, (node) => {
if (node.type === "element" && (node.tagName === "p" || node.tagName === "div")) {
return {
...node,
children: node.children.filter(
(child) => !(child.type === "element" && child.tagName === "img"),
),
};
}
});
// The <img> element has been removed from the treeMengumpulkan semua link
import { visitHast } from "@unifast/core";
import type { HastRoot } from "@unifast/core";
const tree: HastRoot = {
type: "root",
children: [
{
type: "element",
tagName: "p",
properties: {},
children: [
{ type: "text", value: "Visit " },
{
type: "element",
tagName: "a",
properties: { href: "https://example.com" },
children: [{ type: "text", value: "Example" }],
},
{ type: "text", value: " and " },
{
type: "element",
tagName: "a",
properties: { href: "https://docs.example.com" },
children: [{ type: "text", value: "Docs" }],
},
],
},
],
};
const links: string[] = [];
visitHast(tree, (node) => {
if (node.type === "element" && node.tagName === "a") {
const href = node.properties.href;
if (typeof href === "string") {
links.push(href);
}
}
});
console.log(links);
// ["https://example.com", "https://docs.example.com"]Membungkus code block dalam sebuah container
import { visitHast } from "@unifast/core";
import type { HastNode, HastRoot } from "@unifast/core";
const tree: HastRoot = {
type: "root",
children: [
{
type: "element",
tagName: "pre",
properties: {},
children: [
{
type: "element",
tagName: "code",
properties: { className: ["language-js"] },
children: [{ type: "text", value: "const x = 1;" }],
},
],
},
],
};
const result = visitHast(tree, (node) => {
if (node.type === "element" && node.tagName === "pre") {
return {
type: "element",
tagName: "div",
properties: { className: ["code-block"] },
children: [node],
} as HastNode;
}
});
// <pre> is now wrapped inside <div class="code-block">Perilaku
Imutabel: Mengembalikan pohon baru; pohon asli tidak dimodifikasi
Penjelajahan top-down: Visitor dipanggil pada parent sebelum anak-anaknya dikunjungi
Penggantian: Jika visitor mengembalikan sebuah node, node tersebut menggantikan node saat ini sebelum anak-anaknya dijelajahi
No-op: Jika visitor mengembalikan
void(atauundefined), node asli dipertahankanRekursif: Anak-anak dari node
"root"dan"element"dikunjungi secara rekursif