ChartJS 如何在graph.js上为列添加边框

h9a6wy2h  于 2022-11-23  发布在  Chart.js
关注(0)|答案(1)|浏览(170)

我已经把谷歌的数据整理成了一个图表。
我试图更改样式,但无法通过CSS实现。我想为两列都添加边框。
我不能添加所有的代码,但我可以看到这是提到颜色的部分。
https://codepen.io/jameswill77/pen/WNzXxeJ

const colors = ['#FDF7F2', '#23F0C7'];
        dataj = JSON.parse(data.toJSON());
        console.log(dataj.cols[0].label);
        const labels = [];
        for (c = 1; c < dataj.cols.length; c++) {
          if (dataj.cols[c].label != "") {
            labels.push(dataj.cols[c].label);
          }
    
        }
        console.log(labels);
        const datasets = [];
        for (i = 0; i < dataj.rows.length; i++) {
          const series_data = [];
          for (j = 1; j < dataj.rows[i].c.length; j++) {
            if (dataj.rows[i].c[j] != null) {
              if (dataj.rows[i].c[j].v != null) {
                series_data.push(dataj.rows[i].c[j].v);
              } else {
                series_data.push(0);
              }
            }
    
          }
          var dataset = {
            label: dataj.rows[i].c[0].v,
            backgroundColor: colors[i],
            borderColor: colors[i],
            data: series_data
          }
    
          datasets.push(dataset);
    
        }
        console.log(datasets);
    
        const chartdata = {
          labels: labels,
          datasets: datasets
        };
        var canvas = document.getElementById("myChart");
        var setup = {
          type: 'bar',
          data: chartdata,
          options: {
            plugins: {
              title: {
                display: true,
                text: dataj.cols[0].label
              }
            },
            responsive: true,
          }
        }
        chart = new Chart(canvas, setup); 
        
      }
kcugc4gi

kcugc4gi1#

添加了选项borderWidth并更改了datasetsborderColor的值。
https://codepen.io/fver1004/pen/MWVOJpR?editors=1010

google.charts.load('current', { 
    'packages': ['corechart', 'bar']
  });
  google.charts.setOnLoadCallback(initChart);;

  function initChart() {
    URL = "https://docs.google.com/spreadsheets/d/1MV4chXniMBHj1ROAIf-BZR3LsoN-HT180pUwivU5Jbc/edit#gid=2112195720";
    var query = new google.visualization.Query(URL);
    query.setQuery('select *');
    query.send(function(response) {
      handleQueryResponse(response);
    });
  }

  function handleQueryResponse(response) {
    var data = response.getDataTable();
    var columns = data.getNumberOfColumns();
    var rows = data.getNumberOfRows();
    // console.log(data.toJSON());

    const colors = ['#eeeeee', '#23F0C7'];
    const border_colors = ['#ececec', '#21DEC5'];
    dataj = JSON.parse(data.toJSON());
    // console.log(dataj.cols[0].label);
    const labels = [];
    for (c = 1; c < dataj.cols.length; c++) {
      if (dataj.cols[c].label != "") {
        labels.push(dataj.cols[c].label);
      }

    }
    // console.log(labels);
    const datasets = [];
    for (i = 0; i < dataj.rows.length; i++) {
      const series_data = [];
      for (j = 1; j < dataj.rows[i].c.length; j++) {
        if (dataj.rows[i].c[j] != null) {
          if (dataj.rows[i].c[j].v != null) {
            series_data.push(dataj.rows[i].c[j].v);
          } else {
            series_data.push(0);
          }
        }

      }
      var dataset = {
        label: dataj.rows[i].c[0].v,
        backgroundColor: colors[i],
        borderColor: border_colors[i],
        borderWidth: 4,
        data: series_data
      }

      datasets.push(dataset);

    } 
    console.log(datasets);

    const chartdata = {
      labels: labels,
      datasets: datasets
    };
    var canvas = document.getElementById("myChart");
    var setup = {
      type: 'bar',
      data: chartdata,
      options: {
        plugins: {
          title: {
            display: true,
            text: dataj.cols[0].label
          }
        },
        responsive: true,
      }
    }
    chart = new Chart(canvas, setup); 
    
  }

相关问题