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
<template> <dx-chart id="chart" :data-source="dataSource" title="Male Age Structure" > <dx-common-series-settings argument-field="state" type="stackedbar" /> <dx-value-axis position="right"> <dx-title text="millions"/> </dx-value-axis> <dx-series value-field="young" name="0-14" /> <dx-series value-field="middle" name="15-64" /> <dx-series value-field="older" name="65 and older" /> <dx-legend vertical-alignment="bottom" horizontal-alignment="center" item-text-position="top" /> <dx-export :enabled="true"/> <dx-tooltip :enabled="true" :customize-tooltip="customizeTooltip" location="edge" /> </dx-chart> </template> <script> import { DxChart, DxSeries, DxCommonSeriesSettings, DxValueAxis, DxTitle, DxLegend, DxExport, DxTooltip } from 'devextreme-vue/chart'; import service from './data.js'; export default { components: { DxChart, DxSeries, DxCommonSeriesSettings, DxValueAxis, DxTitle, DxLegend, DxExport, DxTooltip }, data() { return { dataSource: service.getMaleAgeData() }; }, methods: { customizeTooltip: (arg) => { return { text: `${arg.seriesName } years: ${ arg.valueText}` }; } } }; </script> <style> #chart { height: 440px; } </style>
import Vue from 'vue'; import App from './App.vue'; new Vue({ el: '#app', components: { App }, template: '<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.3/css/dx.common.css" /> <link rel="dx-theme" data-theme="generic.light" href="https://cdn3.devexpress.com/jslib/19.1.3/css/dx.light.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"> <span v-if="false">Loading...</span> </div> </div> </body> </html>
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/' }, map: { vue: 'npm:vue@2.5.16/dist/vue.esm.browser.js', 'vue-loader': 'npm:systemjs-vue-browser@latest/index.js', 'devextreme': 'npm:devextreme@19.1', 'devextreme-vue': 'npm:devextreme-vue@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', 'plugin-babel': 'npm:systemjs-plugin-babel@0/plugin-babel.js', 'systemjs-babel-build': 'npm:systemjs-plugin-babel@0/systemjs-babel-browser.js' }, meta: { '*.vue': { loader: 'vue-loader' } }, packages: { 'devextreme-vue': { main: 'index.js' }, 'devextreme': { defaultExtension: 'js' } }, babelOptions: { sourceMaps: false, stage0: true } });