2016-08-09 12 views
0

に基づいてHighchartsでシリーズを追加し、シリーズの数は、ユーザが動的highchartで系列を追加する方法ユーザー入力

によって確認されたチェックボックスにアップ依存[アレイ[265]、配列[259]、配列[265]、配列[256]]

私は上記のように配列 - 親の子があるとします。配列の数 - 子はチェックされたチェックボックスに依存します。各配列 - 子は系列を表す必要があります。

+0

あなたはバニラのJavascriptまたは任意のフレームワークを使用していますか? –

+0

いいえ、純粋なJavascriptのみ – MaazKhan47

答えて

2

リスト項目

  • 各チェックし、チェックボックスのための$.highchartseriesプロパティにアイテムをプッシュ機能にonchangeイベントを設定し
  • インデックスデータプロパティで、それぞれの子アレイのチェックボックスを追加します。 。

$(function() { 
 
    /* Build random Data */ 
 
    var randomData = [ 
 
    [], /* Child 0 */ 
 
    [], /* Child 1 */ 
 
    [], /* Child 2 */ 
 
    [], /* Child 3 */ 
 
    ].map(function(child) { 
 
    for (var i = 1; i <= 31; i++) { 
 
     child.push([Date.UTC(2016, 7, i), Math.random()]); 
 
    } 
 
    return child; 
 
    }); 
 

 
    /* Append checkboxes to DOM */ 
 
    randomData.forEach(function(child, i) { 
 
    $('#the-form').append('<input checked type="checkbox" data-index="' + i + '"> Series #' + (i + 1) + '<br>'); 
 
    }); 
 

 
    /* Chart drawing function */ 
 
    var redraw = function() { 
 
    $('#the-chart').highcharts({ 
 
     chart: { 
 
     zoomType: 'x' 
 
     }, 
 
     title: { 
 
     text: 'Random series data over time' 
 
     }, 
 
     subtitle: { 
 
     text: document.ontouchstart === undefined ? 
 
      'Click and drag in the plot area to zoom in' : 'Pinch the chart to zoom in' 
 
     }, 
 
     xAxis: { 
 
     type: 'datetime' 
 
     }, 
 
     yAxis: { 
 
     title: { 
 
      text: 'Some rate' 
 
     } 
 
     }, 
 
     legend: { 
 
     enabled: false 
 
     }, 
 
     plotOptions: { 
 
     area: { 
 
      marker: { 
 
      radius: 2 
 
      }, 
 
      lineWidth: 1, 
 
      states: { 
 
      hover: { 
 
       lineWidth: 1 
 
      } 
 
      }, 
 
      threshold: null 
 
     } 
 
     }, 
 
     series: randomData.filter(function(child, i) { 
 
     /* Choose checked only */ 
 
     return document.querySelector('input[data-index="' + i + '"]').checked 
 
     }).map(function(child, i) { 
 
     /* Then return as series */ 
 
     return { 
 
      type: 'area', 
 
      name: 'Series #' + (i + 1), 
 
      data: child 
 
     }; 
 
     }) 
 
    }); 
 
    }; 
 

 
    /* Call redraw on change */ 
 
    $('input[data-index]').on('change', redraw); 
 

 
    /* And select the first one start */ 
 
    $('input[data-index]:first').val(true); 
 
    redraw(); 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<script src="https://code.highcharts.com/highcharts.js"></script> 
 
<script src="https://code.highcharts.com/modules/exporting.js"></script> 
 
<h3>Select Series</h3> 
 
<div id="the-form"> 
 
</div> 
 
<div id="the-chart" style="min-width: 310px; height: 400px; margin: 0 auto"></div>

+0

ありがとうございましたありがとう(Y) 私のケースでは、私はonchangeプロパティを使用する必要はありません、私は別の送信ボタンを持っています – MaazKhan47

+0

チェックボックスの値を配列に追加しました。 – MaazKhan47

+0

ありがとう私のために働いた:Dありがとう – MaazKhan47

関連する問題