微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

React chart.js 动态数据未更新

如何解决React chart.js 动态数据未更新

我看不到甜甜圈,因为只有在保存 (cntrl+s) 后数据才设置为 [0,0],它会再次使用所需的值进行渲染,并显示甜甜圈。 我正在使用 redux store,一切都在使用代码和操作。 代码

import { Component } from 'react';
import { Doughnut } from 'react-chartjs-2';
import { connect } from 'react-redux';
import { loadToys,removetoy } from '../store/Actions/toyActions'
class _Dashboard extends Component {
    state = {
        data: null
    }
   componentDidMount() {
        this.props.loadToys()
        this.onLoad()
    }
    onLoad = () => {
        const adult = this.props.toys.filter(toy => toy.type === 'Adult').length
        const funny = this.props.toys.filter(toy => toy.type === 'Funny').length
        const educational = this.props.toys.filter(toy => toy.type === 'Educational').length
        this.setState({
            data: {
                labels: ['Adult','Funny','Educational'],datasets:
                    [{
                        backgroundColor: [
                            'rgb(255,99,132)','rgb(54,162,235)','rgb(255,205,86)'
                        ],hoverOffset: 4,data: [adult,funny,educational]
                    }
                    ]

            }
        })
    }
    render() {
        return (
            <div> <h1>Toys by type</h1>
                <Doughnut
                    data={this.state.data}
                    redraw
                />
            </div >
        );
    }
}
const mapGlobalStatetoProps = (state) => {
    return {
        toys: state.toyModule.toys
    }
}
const mapdistpatchToProps = {
    loadToys,removetoy
}
export const Dashboard = connect(mapGlobalStatetoProps,mapdistpatchToProps)(_Dashboard)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。