Adding DOM Attributes
You can set additional HTML attributes on a number of DOM elements inside the editor. There include:
editor:
The editor itself, excluding menus & toolbars.
blockContainer:
The main container element for blocks. Contains both the block's content and its nested blocks.
blockGroup:
The wrapper element for all top-level blocks in the editor and nested blocks.
blockContent:
The wrapper element for a block's content.
inlineContent:
The wrapper element for a block's rich-text content.
In the demo below, we set a custom class on the blockContainer
element to add a border to each block:
import { BlockNoteView, useCreateBlockNote } from "@blocknote/react";
import "@blocknote/react/style.css";
import "./styles.css";
export default function App() {
// Creates a new editor instance.
const editor = useCreateBlockNote({
// Sets attributes on DOM elements in the editor.
domAttributes: {
// Adds a class to all `blockContainer` elements.
blockContainer: {
class: "block-container",
},
},
});
// Renders the editor instance using a React component.
// Adds `data-theming-dom-attributes-demo` to restrict styles to only this demo.
return <BlockNoteView editor={editor} data-theming-dom-attributes-demo />;
}