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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

2回答

1091閲覧

Djangoで管理しているデータをCanvasに描画するには?

donadona

総合スコア19

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2018/12/23 13:55

Python3.6 Django2.1

DjangoでWebアプリケーションを作成しています。

例えば、毎日記録した体重のデータを、HTMLのCanvasに時系列グラフとして描画する場合、
どのようにすればよいのか、方針を教えていただきたいです。
つまり、DjangoとJavascriptの役割分担とデータの引き渡し方法ということになるかと思います。

最初に考えたのは、
DjangoのViewの中で、Javascriptのコード文字列を作成して、テンプレートに引き渡すことですが、
しかしこれだと、表示期間を切り替えるなど軽快に動かすことは難しそうです。

となると、model_listをテンプレートに引き渡して、js側で処理してもらうことになるのでしょうか?
この場合、jsがデータを使用できるように、一旦テンプレート内のどこかに全データを非表示の形でロードするのでしょうか?

具体的な実装方法は調べるつもりですが、
今の時点では方向性がよくわかっていませんので、
考え方だけでもご教授いただければと思います。

よろしくお願いします。

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

Django環境があるわけではないので的確な回答にはなりませんが、
いわゆるサーバーサイドとクライアントサイドのデータ連携という部分ではどの言語もフレームワークも考え方は同じ、ということでヒント回答とさせていただきます。

DjangoのViewの中で、Javascriptのコード文字列を作成して、テンプレートに引き渡すこと

これはそれで良くて、

表示期間を切り替えるなど

クエリストリングを引数として受け取って動的にデータを生成すれば良いのではないでしょうか。
いわゆるGETリクエストですね。

URLで
?year=2018&month=9

ときていればサーバーサイドで2018年9月のデータを取得するとかですね。
もちろん8月~10月のように範囲にしたければパラメータを工夫すれば良いだけです。

投稿2018/12/24 00:34

m.ts10806

総合スコア80850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

donadona

2018/12/24 07:01

ありがとうございます。 2人の方にご回答を頂いて、大雑把に私の考えた2つの方法で、どちらもあり得るのだということが分かりました。 今の目標としては、ブラウザ内で期間を選び直したら、即座に表示が反映されるのが理想なので、 まずはリロードしないで済む2番目の方法で挑戦してみたいと思います。 今後もよろしくお願いします。
m.ts10806

2018/12/24 07:35

なら、ajaxですね。 解決に向かったようで何よりです
guest

0

ベストアンサー

最初に考えたのは、
DjangoのViewの中で、Javascriptのコード文字列を作成して、テンプレートに引き渡すことですが、
しかしこれだと、表示期間を切り替えるなど軽快に動かすことは難しそうです。

となると、model_listをテンプレートに引き渡して、js側で処理してもらうことになるのでしょうか?
この場合、jsがデータを使用できるように、一旦テンプレート内のどこかに全データを非表示の形でロードするのでしょうか?

おそらく一般的なのは後者に近い形です。

グラフを描画する JavaScript のコードのうち、グラフ描画のロジックはすべて Django は介在させない形で .js ファイルに書き、グラフに放り込む最小限のデータの部分だけ JSON を介して Django から JavaScript に渡します。

そのデータの最小単位は例えば次のようなデータ(系列名 + データ)になりますが、この中にどれだけのデータを含めるべきかというのは描画したいグラフの内容等によるので一概には言えません。

json

1{ 2 'series 1': [3, 4, 5], 3 'series 2': [6, 8, 13], 4}

Django から JavaScript にデータを渡す具体的な方法については、「 Django 側でデータを JSON シリアライズしてテンプレート内に出力し、それを JS 側で JSON デシリアライズしてグラフ描画のための関数に渡す」という形が一般的でしょうか。このあたりは Django にズバリそのための機能が備わっていまして、次の質問への回答等がご参考になるのではないかと思います。ご覧になってみてください:

お求めの答えになっているでしょうか。

投稿2018/12/24 06:22

gh640

総合スコア1407

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

donadona

2018/12/24 07:04

ありがとうございます。 このやり方が、私がイメージしていたものに非常に近いと思います。 まだ全然分かりませんが、何を勉強すればよいかが分かりました。 まずはトライしてみて、また疑問が出てきたら別途質問をアップさせていただくかもしれません。 今後とも宜しくお願いします。
gh640

2018/12/25 00:28

それはよかったです。はい、がんばってみてください :)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問