Highcharts

Start your Highcharts journey today

立即试用
立即购买
Skip to Content

HTML Component

The HTML Component serves as a fundamental building block in dashboards. It offers the versatility to incorporate diverse HTML content. It is a simple yet potent tool for constructing dashboards with dynamic content. The configuration structure resembles an Abstract Syntax Tree (AST), enabling definition of tag names, attributes, and nested elements or can be defined as a string representing the HTML code.

Using the HTML component

1. Installation

The HTML component is the simplest component available in Highcharts Dashboards. You can find it in the main Highcharts Dashboards package.

To use it through the CDN, you need to load the following files

<script src="https://code.highcharts.com/dashboards/dashboards.js"></script> <script src="https://code.highcharts.com/dashboards/modules/layout.js"></script>

Alternatively, you can download the NPM package like:

npm install @highcharts/dashboards

and import it in your project like:

import * as Dashboards from '@highcharts/dashboards'; import LayoutModule from '@highcharts/dashboards/modules/layout'; LayoutModule(Dashboards);

2. Layout

After loading the necessary files, define a cell using a unique identifier for the cell, e.g. dashboard-col-0. This cell will be used to place the component in the dashboard.

gui: { layouts: [{ id: 'layout-1', rows: [{ cells: [{ id: 'dashboard-col-0' }] }] }] }

3. Options

When the placeholder is ready, component options can be defined. To do so, set the type of the component to HTML. The type is case-sensitive, so make sure to use the exact spelling.

Apart from the type property, the component requires the cell property to be defined. The cell property is used to specify the cell in which the component should be placed.

4. HTML elements

Now, you can define the HTML elements that will be rendered in the component.

HTML content can be defined in two ways:

  • The elements array is an array of objects, where each object represents a single HTML element. The object usually contains the tagName which is the name of the HTML tag, e.g. div, img, p, etc. and the attributes of the element. If the text should be rendered inside the element, the textContent property can be used.
components: [{ type: 'HTML', renderTo: 'dashboard-col-0', elements: [{ tagName: 'h1', textContent: 'Your text', attributes: { id: 'main-title', } }] }]
  • The html property can be used to define the HTML code as a string.
components: [{ type: 'HTML', renderTo: 'dashboard-col-0', html: '<h1 id="main-title">Your text</h1>' }]

Nested elements

If more than one element is required, the children property can be used. The children property is an array of elements that will be nested inside the parent element. Each element can have its own children elements and is configured in the same way as the parent element.

elements: [{ tagName: 'div', children: [{ tagName: 'h1', textContent: 'Title', attributes: { id: 'main-title', } }, { tagName: 'p', textContent: 'Description', attributes: { id: 'description', } }] }]

Styling the HTML component

The most common way to style the HTML component is to use the CSS and utilize the className or id attributes.

#main-title { color: #4b4b4b; } #description { text-decoration: underline; }

Extending the HTML component

If some of the HTML elements are used frequently or require to be more customizable, it is possible to create a custom component that will simplify the configuration. The custom component can be created by extending the basic HTML component.
More in the Custom Component  section.

Components synchronization

The HTML Component is the only component that does not support any of the predefined synchronization types. However, you can define your own sync types as needed. You can read more about it here .

API options

For the full set of available options, see the API .