为什么HighCharts只写一个我的动态div?

时间:2015-03-23 20:26:19

标签: javascript ruby-on-rails ruby-on-rails-3 highcharts

我正在尝试使用highcharts创建一些图表,并使用动态div来创建。

它在第一张图表上成功,但其余的都是空白的。查看html源我会认为一切正常。

这是我动态创建的div:

  <!-- Break Down of all Signature names in each class -->
      <% n = 0 %>
      <% @sig_class_name_info.each do |scn_chart| %>
          <div>
            <%= scn_chart[:sig_class_name] %>
          </div>
          <table class="table">
            <tr>
              <td style='width:100%'>
                <div class="panel panel-warning well">
                  <div class="panel-heading">
                    <h3 class="panel-title"></h3>
                  </div>
                  <div id="alert_name_bar_chart<%=+n%>" class="panel-body text-center">
                  </div>
                </div>
              </td>
            </tr>
          </table>
          <%n = n+1%>
      <% end %>

这是创建的html源代码:

  <!-- Break Down of all Signature names in each class -->
          <div>
            web-application-attack
          </div>
          <table class="table">
            <tr>
              <td style='width:100%'>
                <div class="panel panel-warning well">
                  <div class="panel-heading">
                    <h3 class="panel-title"></h3>
                  </div>
                  <div id="alert_name_bar_chart0" class="panel-body text-center">
                  </div>
                </div>
              </td>
            </tr>
          </table>
          <div>
            attempted-admin
          </div>
          <table class="table">
            <tr>
              <td style='width:100%'>
                <div class="panel panel-warning well">
                  <div class="panel-heading">
                    <h3 class="panel-title"></h3>
                  </div>
                  <div id="alert_name_bar_chart1" class="panel-body text-center">
                  </div>
                </div>
              </td>
            </tr>
          </table>
          <div>
            misc-attack
          </div>
          <table class="table">
            <tr>
              <td style='width:100%'>
                <div class="panel panel-warning well">
                  <div class="panel-heading">
                    <h3 class="panel-title"></h3>
                  </div>
                  <div id="alert_name_bar_chart2" class="panel-body text-center">
                  </div>
                </div>
              </td>
            </tr>
          </table>
          <div>
            policy-violation
          </div>
          <table class="table">
            <tr>
              <td style='width:100%'>
                <div class="panel panel-warning well">
                  <div class="panel-heading">
                    <h3 class="panel-title"></h3>
                  </div>
                  <div id="alert_name_bar_chart3" class="panel-body text-center">
                  </div>
                </div>
              </td>
            </tr>
          </table>

这是highcharts脚本:

<script type="text/javascript">
            var charts = [];
            $(function () {
                var getChartConfig = function(renderId, title, data, x_axis) {
                    var config = {};
                    config.chart = {
                        renderTo: renderId,
                        defaultSeriesType: 'column',
                        margin: [50, 50, 100, 80]
                    };
                new Highcharts.Chart ({
                    chart: {
                        type: 'bar',
                        renderTo: renderId
                    },
                    title: {
                        text: title,
                        style: {
                            color: '#52508d'
                        }
                    },
                    xAxis: {
                        categories: x_axis
                    },
                    plotOptions: {
                        series: {
                            cursor: 'pointer',
                            point: {
                                events: {
                                    click: function () {
                                        location.href = this.series.options.url;
                                    }
                                }
                            }
                        }
                    },
                    series: [{
                        data: data,
                        showInLegend: false,
                        name: 'Alerts',
                        url: '/ips_alert_classes?query=',
                        color: '#2a2874'
                    }]
                });
                }
                <% n = 0%>
                <% @sig_class_name_info.each do |i| %>
                charts.push(new Highcharts.Chart(
                        getChartConfig("alert_name_bar_chart<%=+n%>",<%= raw i[:sig_class_name].to_json.html_safe %>,<%= raw i[:event_name_count].to_json.html_safe %>,<%= raw i[:event_name].to_json.html_safe %>)
                ))
                <% n = n+1%>
                <% end %>
            });
        </script>

以下是此highcharts脚本中的html源代码:

<script type="text/javascript">
            var charts = [];
            $(function () {
                var getChartConfig = function(renderId, title, data, x_axis) {
                    var config = {};
                    config.chart = {
                        renderTo: renderId,
                        defaultSeriesType: 'column',
                        margin: [50, 50, 100, 80]
                    };
                new Highcharts.Chart ({
                    chart: {
                        type: 'bar',
                        renderTo: renderId
                    },
                    title: {
                        text: title,
                        style: {
                            color: '#52508d'
                        }
                    },
                    xAxis: {
                        categories: x_axis
                    },
                    plotOptions: {
                        series: {
                            cursor: 'pointer',
                            point: {
                                events: {
                                    click: function () {
                                        location.href = this.series.options.url;
                                    }
                                }
                            }
                        }
                    },
                    series: [{
                        data: data,
                        showInLegend: false,
                        name: 'Alerts',
                        url: '/ips_alert_classes?query=',
                        color: '#2a2874'
                    }]
                });

                }
                charts.push(new Highcharts.Chart(
                        getChartConfig("alert_name_bar_chart0", "web-application-attack", [919,1,1,1], ["drop - WP-Admin attempt","Snort Alert [1:16431:5]","Snort Alert [1:19438:9]","drop - SQL use of concat function with select - likely SQL injection"])
                ))
                charts.push(new Highcharts.Chart(
                        getChartConfig("alert_name_bar_chart1", "attempted-admin", [1,10,4], ["Snort Alert [1:31976:4]","drop - SERVER-OTHER Wordpress linenity theme LFI attempt","drop - OS-OTHER Bash CGI environment variable injection attempt"])
                ))
                charts.push(new Highcharts.Chart(
                        getChartConfig("alert_name_bar_chart2", "misc-attack", [1], ["drop - SQL union select - possible sql injection attempt - GET parameter"])
                ))
                charts.push(new Highcharts.Chart(
                        getChartConfig("alert_name_bar_chart3", "policy-violation", [2], ["drop - POLICY-OTHER Adobe ColdFusion admin interface access attempt"])
                ))
            });
        </script>

正如您所看到的,charts.push(new Highcharts.Chart()脚本似乎按预期工作。

什么会导致第一张图表显示正常,但其余图表是空白的?

更新:

这是正在运行的HighCharts设置。

<script type="text/javascript">
            var charts = [];
            $(function () {
                var getChartConfig = function (renderId, title, data, x_axis) {
                    var config = {
                        chart: {
                            renderTo: renderId,
                            defaultSeriesType: 'bar'
                        },
                        title: {
                            text: title,
                            style: {
                                color: '#52508d'
                            }
                        },
                        xAxis: {
                            categories: x_axis
                        },
                        plotOptions: {
                            series: {
                                cursor: 'pointer',
                                point: {
                                    events: {
                                        click: function () {
                                            //location.href = this.series.options.url;
                                        }
                                    }
                                }
                            }
                        },
                        series: [{
                            data: data,
                            showInLegend: false,
                            name: 'Alerts',
                            url: '/signatures?query=',
                            color: '#2a2874'
                        }]
                    };
                    return config;
                }
                <% n = 0%>
                <% @sig_class_name_info.each do |i| %>
                charts.push(new Highcharts.Chart(
                        getChartConfig("alert_name_bar_chart<%=n%>"
                                ,<%= raw i[:sig_class_name].to_json.html_safe %>
                                ,<%= raw i[:event_name_count].to_json.html_safe %>
                                ,<%= raw i[:event_name].to_json.html_safe %>)
                ))
                <% n = n+1%>
                <% end %>
            });
        </script>

1 个答案:

答案 0 :(得分:0)

重要的一点是:你创建每个图表两次,第一次调用getChartConfig时,第二次创建图表数组。所以我建议改变:

仅限图表:

charts.push(getChartConfig(...)) 

并在getChartConfig方法中,返回创建的图表:

 return new Highcharts.Chart ({ ... });