visitHast()
Parcourt et transforme un arbre HAST au moyen d'une fonction visiteur.
import { visitHast } from "@unifast/core";Signature
function visitHast(node: HastNode, visitor: (node: HastNode) => HastNode | void): HastNodeParamètres
node
| Propriété | Type | Défaut | Description |
|---|---|---|---|
type | string | — | Le type de nœud ("root", "element", "text", etc.) |
children | HastNode[] | — | Nœuds enfants (pour les types "root" et "element") |
visitor
| Propriété | Type | Défaut | Description |
|---|---|---|---|
visitor | (node: HastNode) => HastNode | void | — | Une fonction appelée pour chaque nœud ; retournez un nœud pour remplacer l’original, ou void pour le conserver |
Valeur de retour
HastNode — Un nouvel arbre sur lequel ont été appliquées les transformations de la fonction visiteur.
Utilisation
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"Exemples
Ajouter une classe à tous les paragraphes
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"]Supprimer toutes les images
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 treeCollecter tous les liens
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"]Envelopper les blocs de code dans un conteneur
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">Comportement
Immuable : Renvoie un nouvel arbre ; l’arbre original n’est pas modifié
Parcours descendant : Le visiteur est appelé sur le parent avant que ses enfants ne soient visités
Remplacement : Si le visiteur renvoie un nœud, il remplace le nœud courant avant que les enfants ne soient parcourus
Aucune modification : Si le visiteur renvoie
void(ouundefined), le nœud d’origine est conservéRécursif : Les enfants des nœuds
"root"et"element"sont visités récursivement