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

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

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

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

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

Q&A

1回答

1062閲覧

viewから受け取った辞書を、HTML内でそのまま使いたい

sahksas

総合スコア28

Django

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

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

0グッド

0クリップ

投稿2020/12/28 20:44

編集2020/12/28 20:46

Djangoのテンプレート関数を使って、viewから受けた値をHTMLで使っていますが、辞書の扱い方で困っています。

具体的には、受け取った辞書をHTML内のJSでそのまま辞書型の変数として扱いたいのですが、文字化けが起こりうまくいきません。

実際のコードは下記のようなものです。

python

1class Home(View): 2 def get(self, request, *args, **kwargs): 3 context = {} 4 context[“jisho”] = { 5 “one”: “いち”, 6 “two”: “に”, 7 } 8 return render(request, home.html, context)

html

1<script> 2 $(function () { 3 const jisho = {{ jisho }} // ここへ期待通りの辞書が入らない 4 }) 5 $(“#sentaku”).change(function () { 6 alert(jisho[$(this).val()]) 7 }) 8</script> 9<select id=“sentaku”> 10 <option value=“one”>ichi</option> 11 <option value=“two”>ni</option> 12</select>

一度、

html

1let jisho = {} 2jisho[“one”] = {{ jisho.one }} 3jisho[“two”] = {{ jisho.two }}

のように分解して作り直すしか方法は無さそうでしょうか。

どうぞよろしくお願い致します。

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

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

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

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

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

m.ts10806

2020/12/28 21:37

djangoのことはよく分かりませんが「文字化け」がどういう出力なのか提示されたほうが良いように思います。 オブジェクト(JSON含め)使っている場合、実際は文字化けではないということもあり得ますので。
guest

回答1

0

提示されたHTMLはそれで全てでしょうか?
html、head、meta、bodyタグなどはきちんと記載はありますでしょうか?
あと、テキストのエンコーディングはutf-8?
ブラウザによっては文字化けします。たしかFirefoxだったかな?

あと、DjangoからHTMLのView(JS)に値を引き渡したい場合、通常、JSONに変換してください。
Django(python)が出力する"文字列"をJavaScriptで認識するためには何かしらの変換が必要です(言語がそもそも違うので)
言語問わずやり取りしたいのであればxml、jsonなどがありますが、jsonのほうが軽量でやり取りしやすいのでオススメです。

JSONへの変換の仕方に関しては以下のを参考にしてみてください。
https://qiita.com/Morio/items/7538a939cc441367070d

投稿2020/12/29 00:48

deo_deo

総合スコア198

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問