Hello World
\"}\nHello World
\");\n ```\n\n #### Utility `renderHTML()`\n\n Utility standalone per il rendering al di fuori dei componenti.\n\n ```tsx\n import { renderHTML } from \"react-intlayer/html\";\n\n const jsx = renderHTML(\"Hello
\", { components: { p: 'div' } });\n ```\n\nHello World
\")}\n ```\n\n #### Utility `renderHTML()`\n\n ```svelte\n \n\n {@html renderHTML(\"Hello World
\")}\n ```\n\nHello World
\"}\nHello World
\")}Hello World
\")}Hello World
\"}\nHello World
\")}Hello World
\")}Pose una domanda e ottieni un riassunto del documento facendo riferimento a questa pagina e al provider AI di tua scelta
Cronologia delle versioni
- "Add `intlayerHTML` plugin object; use `app.use(intlayerHTML)` instead of `app.use(installIntlayerHTML)`"v8.5.024/03/2026
- "spostare l'importazione da {{framework}}-intlayer a {{framework}}-intlayer/html"v8.5.024/03/2026
- "Aggiunta dell'utility HTMLRenderer / useHTMLRenderer / renderHTML"v8.0.022/01/2026
- "Aggiunto il supporto per il parsing HTML"v8.0.020/01/2026
Il contenuto di questa pagina è stato tradotto con un'IA.
Vedi l'ultima versione del contenuto originale in ingleseSe hai un’idea per migliorare questa documentazione, non esitare a contribuire inviando una pull request su GitHub.
Collegamento GitHub alla documentazioneCopia il Markdown del documento nella porta-documenti
Contenuto HTML / HTML in Intlayer
Intlayer supporta contenuti HTML, permettendoti di incorporare contenuti ricchi e strutturati all'interno dei tuoi dizionari. Questi contenuti possono essere renderizzati con tag HTML standard o sostituiti con componenti personalizzati a runtime.
Dichiarare contenuti HTML
Puoi dichiarare contenuti HTML usando la funzione html o semplicemente come stringa.
Usa la funzione html per dichiarare esplicitamente contenuti HTML. Questo garantisce che i tag standard siano mappati correttamente anche se il rilevamento automatico è disabilitato.
Copiare il codice nella clipboard
import { html, type Dictionary } from "intlayer";const htmlDictionary = { key: "app", contentAutoTransformation: true, // può essere impostato nel file di configurazione content: { myHtmlContent: html("<p>Ciao <strong>Mondo</strong></p>"), },} satisfies Dictionary;export default htmlDictionary;Il nodo html()
La funzione html() è una nuova funzionalità di Intlayer v8 che consente di definire esplicitamente il contenuto HTML nei dizionari. Sebbene Intlayer sia spesso in grado di rilevare automaticamente il contenuto HTML, l'uso della funzione html() offre diversi vantaggi:
- Sicurezza dei tipi: La funzione
html()consente di definire le prop attese per i componenti personalizzati, offrendo un migliore completamento automatico e controllo dei tipi nel proprio editor. - Dichiarazione esplicita: Garantisce che una stringa venga sempre trattata come HTML, anche se non contiene tag HTML standard che attiverebbero il rilevamento automatico.
- Definizione di componenti personalizzati: È possibile passare un secondo argomento a
html()per definire i componenti personalizzati e i tipi di prop attesi.
Copiare il codice nella clipboard
import { html } from "intlayer";const myContent = html( "<MyCustomComponent title='Ciao'>Mondo</MyCustomComponent>", { MyCustomComponent: { title: "string", children: "node", }, });Quando si utilizza il metodo .use() su un nodo HTML, i componenti forniti verranno controllati rispetto alla definizione fornita nella funzione html() (se disponibile).
Rendering dell'HTML
Il rendering può essere gestito automaticamente dal sistema di contenuti di Intlayer o manualmente utilizzando strumenti specializzati.
Rendering automatico (usando useIntlayer)
Quando accedi al contenuto tramite useIntlayer, i nodi HTML sono già pronti per il rendering.
I nodi HTML possono essere renderizzati direttamente come JSX. I tag standard funzionano automaticamente.
Copiare il codice nella clipboard
import { useIntlayer } from "react-intlayer";const AppContent = () => { const { myHtmlContent } = useIntlayer("app"); return <div>{myHtmlContent}</div>;};Usa il metodo .use() per fornire componenti personalizzati o sovrascrivere i tag:
Copiare il codice nella clipboard
{myHtmlContent.use({ p: (props) => <p className="prose" {...props} />, CustomLink: ({ children }) => <a href="/details">{children}</a>,})}Configurazione globale con HTMLProvider
Puoi configurare il rendering HTML a livello globale per l'intera applicazione. Questo è ideale per definire componenti personalizzati che dovrebbero essere disponibili in tutti i contenuti HTML.
Copiare il codice nella clipboard
import { HTMLProvider } from "react-intlayer/html";export const AppProvider = ({ children }) => ( <HTMLProvider components={{ p: (props) => <p className="prose" {...props} />, CustomLink: ({ children }) => <a href="/details">{children}</a>, }} > {children} </HTMLProvider>);Puoi anche utilizzare il tuo motore di rendering HTML:
Copiare il codice nella clipboard
import { HTMLProvider } from "react-intlayer/html";export const AppProvider = ({ children }) => ( <HTMLProvider renderHTML={async (html) => { const { renderHTML } = await import('react-intlayer/html'); return renderHTML(html); }} > {children} </HTMLProvider>);Importare dinamicamente il tuo renderer HTML è un ottimo modo per ridurre le dimensioni del bundle della tua applicazione.
Rendering manuale e strumenti avanzati
Se hai bisogno di renderizzare stringhe HTML grezze o di avere un controllo maggiore sulla mappatura dei componenti, usa i seguenti strumenti.
Componente <HTMLRenderer />
Esegui il rendering di una stringa HTML con componenti specifici.
Copiare il codice nella clipboard
import { HTMLRenderer } from "react-intlayer/html";<HTMLRenderer components={{ p: MyCustomP }}> {"<p>Hello World</p>"}</HTMLRenderer>Hook useHTMLRenderer()
Ottieni una funzione di rendering preconfigurata.
Copiare il codice nella clipboard
import { useHTMLRenderer } from "react-intlayer/html";const renderHTML = useHTMLRenderer({ components: { strong: (props) => <strong {...props} className="text-red-500" /> }});return renderHTML("<p>Hello <strong>World</strong></p>");Utility renderHTML()
Utility standalone per il rendering al di fuori dei componenti.
Copiare il codice nella clipboard
import { renderHTML } from "react-intlayer/html";const jsx = renderHTML("<p>Hello</p>", { components: { p: 'div' } });Riferimento delle opzioni
Queste opzioni possono essere passate a HTMLProvider, HTMLRenderer, useHTMLRenderer, e renderHTML.
Apri la tabella in una finestra modale per visualizzare tutti i dati in modo chiaro
| Opzione | Tipo | Predefinito | Descrizione |
|---|---|---|---|
components | Record<string, any> | {} | Una mappa che associa tag HTML o nomi di componenti personalizzati ai componenti. |
renderHTML | Function | null | Una funzione di rendering personalizzata per sostituire completamente il parser HTML predefinito (solo per i provider Vue/Svelte). |
Nota: per React e Preact, i tag HTML standard sono forniti automaticamente. È necessario passare la prop components solo se si desidera sovrascriverli o aggiungere componenti personalizzati.