如何从chart.js的html表动态添加元素

时间:2013-07-25 22:25:17

标签: javascript html charts html-table

任何人都可以帮忙解决这个问题吗?

我正在使用chart.js将图表开发到我的asp.net mvc C#应用程序中。

问题是我无法将html表中的元素动态添加到图表中。

<canvas id="myChart" width="600" height="400"></canvas> //html5 canvas    
   <script type="text/javascript">    
            var ctx = document.getElementById("myChart").getContext("2d");    
            var data = {                                 
                datasets: [    
                           {
                              fillColor: "rgba(223,104,27,0.5)",    
                              strokeColor: "rgba(220,220,220,1)",    
                              data: getcountdata1()    
                            },    
                            {    
                               fillColor: "rgba(151,187,205,0.5)",    
                               strokeColor: "rgba(151,187,205,1)",    
                               data: getcountdata2()    
                          }]    
   myNewChart = new Chart(ctx).Line(data, options);

以上工作正常,因为在数据集中我正在硬编码数据集中的元素数量,但实际上这应该检查HTML表并从表中获取数据。

现在的问题是如何根据表格中的行数使数据集获得动态值?

例如我已经编写了一个Javascript函数(我已经尝试过以下的男女同志):

var data: 
{            
 datasets: getdata()
}

function getdata()
{
rows = document.getElementById('tblresult').getElementsByTagName('tbody')[0].getElementsByTagName('tr').length;    
for(i=0;i<rows;i++)
{
  datasetdata[i] = [
             {
                 fillColor: getrandomfillcolor(),    
                 strokeColor: getrandomstrokecolor(),    
                 data: getcountdata()

             }]
}

function getrandomfillcolor()
{
}

function getrandomstrokecolor()
{
}

function getcountdata()
{
}

return datasetdata

             }

我已经尝试了好几次但是却找不到解决办法。

1 个答案:

答案 0 :(得分:0)

您需要将每一行传递给getcountdata()函数

rowsDomElements = document.getElementById('tblresult').getElementsByTagName('tbody')[0].getElementsByTagName('tr');

for(i=0;i<rowsDomElements.length;i++)
{
    datasetdata[i] = [
    {
         fillColor: getrandomfillcolor(),
         strokeColor: getrandomstrokecolor(),
         data: getcountdata(rowsDomElements[i])
    }]
}

function getcountdata(row)
{
    //create data as needed
}