10

我对 react-chartjs-2 中的条形图有疑问。我在我的应用程序中使用 react-chartjs-2 制作了条形图和饼图。

我可以使用一个名为 Chart.PieceLabel.js的插件来显示饼图的值。但我找不到条形图的插件。我想将每个条形图的值显示为与饼图相同。

是否可以对条形图中的每个条形进行赋值?

目前的看法是这样的。在饼图中,显示每个切片的值。

在此处输入图像描述

这是我的代码

export default class Categories extends React.Component{
constructor(props){
    super(props);
    this.state = {
        slideOpen : false,
        piData : piData
      }

this.handleClick = this.handleClick.bind(this);
this.update = this.update.bind(this);
this.doParentToggle = this.doParentToggle.bind(this);
}

doParentToggle(){


this.setState({
    piData : piData
  })
  this.update();
  }

handleClick(){
    this.setState({
        slideOpen : !this.state.slideOpen
    })
    }

update() {
  var piData;
  this.setState({
    piData : piData
  })
}    

  componentDidMount() {
    let ctx = this.refs.chart.chart_instance.chart.ctx;
    console.log(this.refs.chart.chart_instance.chart.ctx); // returns a Chart.js instance reference
    this.refs.chart.chart_instance.chart.config.data.datasets.forEach(function (dataset) {
                if(dataset.type === 'bar'){
                    const dataArray = dataset.data;
                    dataset._meta[0].data.forEach(function (bar, index) {
                        ctx.fillText(dataArray[index], bar._view.x, bar._view.y);
                    });
                };
            })
  }

render(){


 const CategoriesPanel = this.state.slideOpen? "slideOpen" : "";
 const { length } = this.props


  var totalData = piData + piData2 + piData3 + piData4 + piData5;

   let newpiData =  function() {
   return parseFloat((piData /  totalData ) * 100 ).toFixed(2) };

   let newpiData2 =  function() {
   return parseFloat((piData2 /  totalData ) * 100).toFixed(2) };

   let newpiData3 =  function() {
   return  parseFloat((piData3 /  totalData ) * 100).toFixed(2) };

   let newpiData4 =  function() {
   return parseFloat((piData4 /  totalData ) * 100).toFixed(2) };

   let newpiData5 =  function() {
   return parseFloat((piData5 /  totalData ) * 100).toFixed(2) };

  const data = {
  datasets: [{
    data: [ newpiData() , newpiData2(), newpiData3(), newpiData4(), newpiData5()],
    backgroundColor: [
    'orange',
    'blue',
    'red',
    'purple',
    'green'
    ],
    borderColor: [ 
    'orange',
    'blue',
    'red',
    'purple',
    'green'
    ]
  }]};

  var pieOptions = {
      pieceLabel: {
     render: function (args) {
              return args.value + '%';
            },
     fontSize: 40,
     fontColor: '#fff'
   }
  };

  const bardata = {
  labels: ['1', '2', '3', '4', '5'],
  datasets: [
   {
  backgroundColor: [
    'orange',
    'blue',
    'red',
    'purple',
    'green'
    ],
  borderColor: 'black',
  borderWidth: 3,
  hoverBackgroundColor: 'rgba(255,99,132,0.4)',
  hoverBorderColor: 'rgba(255,99,132,1)',
  data: [ piData , piData, piData , piData , piData ]
  }
  ]
  };

  return(
<div>
<div id="chart" className={CategoriesPanel}>
<div style={{"display" : "flex"}}>
<Pie style={{"fontSize" : "20px" }} data={data} options={pieOptions}/>
<HorizontalBar
      ref='chart'
      data={bardata}
      width={100}
      height={50}
      options={{
        maintainAspectRatio: false
      }}
    />
  </div>
 </div>
<div className="categoriesSlide" onClick={this.handleClick}>{this.state.slideOpen? <img src={Arrowup} alt="arrowup" className="arrowup" /> : <img src={Arrowdown} alt="arrowdown" className="arrowdown"/>}</div>
 <div className="clear">
 <List parentToggle={this.doParentToggle} />
 <ListSecond parentToggle={this.doParentToggle} />
 <ListThird parentToggle={this.doParentToggle} />
 <ListFourth parentToggle={this.doParentToggle} />
 <ListFifth parentToggle={this.doParentToggle} />

 </div>
 </div>
    )
}
}

感谢您的帮助,感谢您花时间阅读我的问题。

4

3 回答 3

31

要在每个柱上显示数据值,您可以使用一个名为:chartjs-plugin-datalabels 的插件

安装(通过 npm)

npm install chartjs-plugin-datalabels --save

导入(在组件中)

import 'chartjs-plugin-datalabels';

选项(显示价值)

plugins: {
   datalabels: {
      display: true,
      color: 'white'
   }
}

* 在图表选项中添加这个

在此处查看datalables 插件的所有可用选项。

于 2017-09-27T20:35:21.027 回答
5

如果您将它用于 React 应用程序,则在您的主 index.js 文件中导入“chartjs-plugin-datalabels”。这将自动将数据标签添加到所有图表。为了从特定图表中删除不需要的数据标签,请将以下内容添加到相应的选项对象中:

options = { plugins: { datalabels: { display: false }}}
于 2018-11-13T21:05:36.650 回答
0

首先安装 chartjs-plugin-datalabels

npm install chartjs-plugin-datalabels --save

然后导入它和 Chart.js

import Chart from 'chart.js';
import ChartDataLabels from 'chartjs-plugin-datalabels';

然后注册

const MyFunction = () => {
   Chart.plugins.register(ChartDataLabels);
...
}

最后在选项中使用它

 options: {
  plugins: {
    datalabels: {
      color: '#36A2EB'
    }
  }
}

您可以在网站上找到此信息

于 2021-06-14T22:31:22.050 回答