--- description: Add an image (but a beautiful one), when words aren’t enough. icon: image-line --- # Image [![Version](https://img.shields.io/npm/v/@tiptap/extension-image.svg?label=version)](https://www.npmjs.com/package/@tiptap/extension-image) [![Downloads](https://img.shields.io/npm/dm/@tiptap/extension-image.svg)](https://npmcharts.com/compare/@tiptap/extension-image?minimal=true) Use this extension to render `` HTML tags. By default, those images are blocks. If you want to render images in line with text set the `inline` option to `true`. :::warning Restrictions This extension does only the rendering of images. It doesn’t upload images to your server, that’s a whole different story. ::: ## Installation ```bash # with npm npm install @tiptap/extension-image # with Yarn yarn add @tiptap/extension-image ``` ## Settings ### HTMLAttributes Custom HTML attributes that should be added to the rendered HTML tag. ```js Image.configure({ HTMLAttributes: { class: 'my-custom-class', }, }) ``` ### inline Renders the image node inline, for example in a paragraph tag: `

`. By default images are on the same level as paragraphs. It totally depends on what kind of editing experience you’d like to have, but can be useful if you (for example) migrate from Quill to Tiptap. Default: `false` ```js Image.configure({ inline: true, }) ``` ## Commands ### setImage() Makes the current node an image. ```js editor.commands.setImage({ src: 'https://example.com/foobar.png') editor.commands.setImage({ src: 'https://example.com/foobar.png', alt: 'A boring example image', title: 'An example' }) ``` ## Source code [packages/extension-image/](https://github.com/ueberdosis/tiptap/blob/main/packages/extension-image/) ## Usage https://embed.tiptap.dev/preview/Nodes/Image