質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.99%

【highcharts】同じ種類のグラフを複数表示したい

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,679

pecchan

score 268

【やりたいこと】
PHP+「highcharts」でグラフ作成に挑戦してます。
同一ページ内に、同じ種類のグラフを複数作成したいです。
※グラフ数は可変

【参考にしたページ】
円グラフ

例えばこの円グラフを3つにしたい場合です。
※数値データ自体はもちろん変えて

【調べた結果】
別種類のグラフを重ねたり、別種類のグラフを複数表示する方法は見つかりました。
ですが、今回やりたいことは「同じ種類の」グラフなので違うようでした。

【質問】
実現するにはどんな方法があるでしょうか?

グラフを作成したい回数だけhighchartsの「グラフ生成メソッド」を呼べば良いと考えましたが
html(view)側からjqueryのメソッドを複数回呼ぶことは可能なのでしょうか?
まずここが分かりません。

あるいは、jqueryのメソッド側を修正すべきでしょうか?

よければアドバイス宜しくお願い致します。

<script type="text/javascript">
$(function () {
    $('#container').highcharts({
        chart: {
            type: 'pie',
        },
        series: [{
            data: [
                ['Firefox',<?php echo $f_count; ?>],
                ['IE', <?php echo $i_count; ?>],
                ['Chrome', <?php echo $c_count; ?>],
                ['Safari', <?php echo $s_count; ?>],
                ['Opera', <?php echo $o_count; ?>],
                ['Others', <?php echo $others; ?>]
            ]
        }]
    });
});
</script>
コード
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • kei344

    2016/04/24 14:24

    現在書かれている、JavaScriptのコードを追記されれば、回答を受けやすいと思います。

    キャンセル

  • pecchan

    2016/04/24 15:20

    有難う御座います。
    コードを追記致しました。

    キャンセル

回答 2

checkベストアンサー

+1

こんな感じで動きませんか?

<script type="text/javascript">
$(function () {
    $('#container1').highcharts({
        chart: {
            type: 'pie',
        },
        series: [{
            data: [
                ['Firefox',<?php echo $c1_f_count; ?>],
                ['IE', <?php echo $c1_i_count; ?>],
                ['Chrome', <?php echo $c1_c_count; ?>],
                ['Safari', <?php echo $c1_s_count; ?>],
                ['Opera', <?php echo $c1_o_count; ?>],
                ['Others', <?php echo $c1_others; ?>]
            ]
        }]
    });
    $('#container2').highcharts({
        chart: {
            type: 'pie',
        },
        series: [{
            data: [
                ['Firefox',<?php echo $c2_f_count; ?>],
                ['IE', <?php echo $c2_i_count; ?>],
                ['Chrome', <?php echo $c2_c_count; ?>],
                ['Safari', <?php echo $c2_s_count; ?>],
                ['Opera', <?php echo $c2_o_count; ?>],
                ['Others', <?php echo $c2_others; ?>]
            ]
        }]
    });
});
</script>
<div id="container1"></div>
<div id="container2"></div>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/04/24 15:39

    kei344様

    すいません。
    冗長になるのは避けたいためご相談させていただきました。

    同じ処理なので処理は「1つ」だけで実現したいです。

    記載の通り、作成するグラフの数は可変(1~n個)です。
    ※いくつ作成するかは画面からの指定次第。

    なので、こちらの方法ですとグラフの数だけ処理は増えるので
    対応出来ないです。




    キャンセル

  • 2016/04/24 16:06

    > html(view)側からjqueryのメソッドを複数回呼ぶことは可能なのでしょうか?
    これに対して回答したつもりでした。複数回呼ぶことは可能です。

    もう少し丁寧に回答できるように心がけます。

    キャンセル

0

foreach
で作成するグラフ数分、
出力することにしました。

お騒がせしました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.99%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる