Angular 中包含三个部分的单个堆叠条
Single Stacked bar with three sections in Angular
我是 angular 的新手。我想要实现 vertical bar
或三种颜色的堆叠条。颜色区域取决于 Accept -10, reject-6, pending -20
.
等值
当我点击一个部分时,它应该触发该事件。
我有需求截图
我浏览了很多文章,但它们显示的图表包含多个垂直条,而不是单个。 This and this
我该如何实施?
经过一天的奋斗,我终于用Chart.js
开发了它
ngOnInit() {
this.chart = new Chart("Chart1", {
type: 'bar',
data: {
labels: [''],
datasets: [{
pointHoverBackgroundColor: 'red',
label: 'Unenrolled',
data: [27],
backgroundColor:"#FF1C00"
},
{
label: 'Enrolled',
data: [40],
backgroundColor:"#ED872D"
},
{
label: 'Registerded',
data: [12],
strokeColor: "#F29220",
backgroundColor:"#318CE7"
}
],
},
options: {
tooltips: {
mode: 'dataset'
},
responsive: true,
legend: {
display: true,
position: 'bottom',
labels: {
fontSize: 10,
usePointStyle: true
}
},
scales: {
yAxes: [{
type: 'linear',
display: true,
position:"left",
barRoundness: 0.3,
barPercentage: 0.4,
stacked: true,
ticks: {
stepSize: 20,
suggestedMax: 80,
beginAtZero: true
}
}],
xAxes: [{
position:"right",
stacked: true,
display: true,
scaleLabel: {
display: true,
labelString: ''},
barPercentage: 0.3,
barRoundness: 0.3,
ticks: {
beginAtZero: true
}
}]
}
}
});
};
showData(evt:any)
{
var data = this.chart.getElementsAtEvent(evt)
console.log(data[0]._model); // it prints the value of the property
}
这是 html
和 css
文件
<div id="mydiv">
<canvas id="Chart1" height="30px" (click)="showData($event)"></canvas>
</div>
#mydiv
{
display: block;
width: 300px;
height: 400px;
}
输出截图:
我是 angular 的新手。我想要实现 vertical bar
或三种颜色的堆叠条。颜色区域取决于 Accept -10, reject-6, pending -20
.
当我点击一个部分时,它应该触发该事件。
我有需求截图
我浏览了很多文章,但它们显示的图表包含多个垂直条,而不是单个。 This and this
我该如何实施?
经过一天的奋斗,我终于用Chart.js
ngOnInit() {
this.chart = new Chart("Chart1", {
type: 'bar',
data: {
labels: [''],
datasets: [{
pointHoverBackgroundColor: 'red',
label: 'Unenrolled',
data: [27],
backgroundColor:"#FF1C00"
},
{
label: 'Enrolled',
data: [40],
backgroundColor:"#ED872D"
},
{
label: 'Registerded',
data: [12],
strokeColor: "#F29220",
backgroundColor:"#318CE7"
}
],
},
options: {
tooltips: {
mode: 'dataset'
},
responsive: true,
legend: {
display: true,
position: 'bottom',
labels: {
fontSize: 10,
usePointStyle: true
}
},
scales: {
yAxes: [{
type: 'linear',
display: true,
position:"left",
barRoundness: 0.3,
barPercentage: 0.4,
stacked: true,
ticks: {
stepSize: 20,
suggestedMax: 80,
beginAtZero: true
}
}],
xAxes: [{
position:"right",
stacked: true,
display: true,
scaleLabel: {
display: true,
labelString: ''},
barPercentage: 0.3,
barRoundness: 0.3,
ticks: {
beginAtZero: true
}
}]
}
}
});
};
showData(evt:any)
{
var data = this.chart.getElementsAtEvent(evt)
console.log(data[0]._model); // it prints the value of the property
}
这是 html
和 css
文件
<div id="mydiv">
<canvas id="Chart1" height="30px" (click)="showData($event)"></canvas>
</div>
#mydiv
{
display: block;
width: 300px;
height: 400px;
}
输出截图: