Your search did not match any results.
Bar Charts

Stacked Bar

Documentation

This demo illustrates the use of the stacked bar series type. Unlike side-by-side bar charts, this series is able to present both the proportion and the total value for each data category using rectangular bars stacked on top of one another.

www.geohive.com
Copy to CodeSandBox
Apply
Reset
import React from 'react'; import { Chart, Series, CommonSeriesSettings, Legend, ValueAxis, Title, Export, Tooltip } from 'devextreme-react/chart'; import service from './data.js'; const dataSource = service.getMaleAgeData(); class App extends React.Component { customizeTooltip(arg) { return { text: `${arg.seriesName } years: ${ arg.valueText}` }; } render() { return ( <Chart id={'chart'} title={'Male Age Structure'} dataSource={dataSource} > <CommonSeriesSettings argumentField={'state'} type={'stackedBar'} /> <Series valueField={'young'} name={'0-14'} /> <Series valueField={'middle'} name={'15-64'} /> <Series valueField={'older'} name={'65 and older'} /> <ValueAxis position={'right'}> <Title text={'millions'} /> </ValueAxis> <Legend verticalAlignment={'bottom'} horizontalAlignment={'center'} itemTextPosition={'top'} /> <Export enabled={true} /> <Tooltip enabled={true} location={'edge'} customizeTooltip={this.customizeTooltip} /> </Chart> ); } } export default App;
import React from 'react'; import ReactDOM from 'react-dom'; import App from './App.js'; ReactDOM.render( <App />, document.getElementById('app') );
<!DOCTYPE html> <html> <head> <title>DevExtreme Demo</title> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/19.1.4/css/dx.common.css" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/19.1.4/css/dx.light.css" /> <link rel="stylesheet" type="text/css" href="styles.css" /> <script src="https://unpkg.com/core-js@2.4.1/client/shim.min.js"></script> <script src="https://unpkg.com/systemjs@0.21.3/dist/system.js"></script> <script type="text/javascript" src="config.js"></script> <script type="text/javascript"> System.import('./index.js'); </script> </head> <body class="dx-viewport"> <div class="demo-container"> <div id="app"></div> </div> </body> </html>
#chart { height: 440px; }
const maleAgeData = [{ state: 'Germany', young: 6.7, middle: 28.6, older: 5.1 }, { state: 'Japan', young: 9.6, middle: 43.4, older: 9 }, { state: 'Russia', young: 13.5, middle: 49, older: 5.8 }, { state: 'USA', young: 30, middle: 90.3, older: 14.5 }]; export default { getMaleAgeData() { return maleAgeData; } };
System.config({ transpiler: 'plugin-babel', paths: { 'npm:': 'https://unpkg.com/' }, defaultExtension: 'js', map: { 'react': 'npm:react@16/umd/react.development.js', 'react-dom': 'npm:react-dom@16/umd/react-dom.development.js', 'prop-types': 'npm:prop-types/prop-types.js', 'devextreme': 'npm:devextreme@19.1', 'devextreme-react': 'npm:devextreme-react@19.1', 'jszip': 'npm:jszip@3.1.3/dist/jszip.min.js', 'quill': 'npm:quill@1.3.6/dist/quill.js', 'devexpress-diagram': 'npm:devexpress-diagram', // SystemJS plugins 'plugin-babel': 'npm:systemjs-plugin-babel@0/plugin-babel.js', 'systemjs-babel-build': 'npm:systemjs-plugin-babel@0/systemjs-babel-browser.js' }, packages: { 'devextreme': { defaultExtension: 'js' }, 'devextreme-react': { main: 'index.js' } }, babelOptions: { sourceMaps: false, stage0: true, react: true } });