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

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

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

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

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

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

Python

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

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

Q&A

解決済

1回答

1943閲覧

Djangoでajaxを使ってpost通信でjsonデータを送信する方法

退会済みユーザー

退会済みユーザー

総合スコア0

Django

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

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

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

Python

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

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

0グッド

1クリップ

投稿2018/12/28 04:18

ajaxを使ってpost通信でjsonデータを送信するプログラムです。
私はdjangoを使っています。

質問が二つあります。
一つ目
urlには、表示するurlを入れればいいのですか?

二つ目jsonを送信する部分はどこになりますか。
$.ajax({
~~~
$("#response").html(JSON.stringify(data));
~~~
)}
ここになりますか?

html

1<!DOCTYPE html> 2<html> 3<head> 4<meta charset="UTF-8"> 5<title>HTMLファイルからPOSTでJSONデータを送信する</title> 6<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script> 7 8<script type="text/javascript"> 9 $(function(){ 10 $("#response").html("Response Values"); 11 12 $("#button").click( function(){ 13 var url = $("#url_post").val(); 14 15 var JSONdata = { 16 value1: $("#value1").val(), 17 value2: $("#value2").val() 18 }; 19 20 alert(JSON.stringify(JSONdata)); 21 22 $.ajax({ 23 type : 'post', 24 url : url, 25 data : JSON.stringify(JSONdata), 26 contentType: 'application/JSON', 27 dataType : 'JSON', 28 scriptCharset: 'utf-8', 29 success : function(data) { 30 31 // Success 32 alert("success"); 33 alert(JSON.stringify(data)); 34 $("#response").html(JSON.stringify(data)); 35 }, 36 error : function(data) { 37 38 // Error 39 alert("error"); 40 alert(JSON.stringify(data)); 41 $("#response").html(JSON.stringify(data)); 42 } 43 }); 44 }) 45 }) 46</script> 47 48</head> 49<body> 50 <h1>HTMLファイルからPOSTでJSONデータを送信する</h1> 51 <p>URL: <input type="text" id="url_post" name="url" size="100" value="http://testurl/"></p> 52 <p>value1: <input type="text" id="value1" size="30" value="値1"></p> 53 <p>value2: <input type="text" id="value2" size="30" value="値2"></p> 54 <p><button id="button" type="button">submit</button></p> 55 <textarea id="response" cols=120 rows=10 disabled></textarea> 56</body> 57</html>

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

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

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

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

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

guest

回答1

0

ベストアンサー

一つ目

urlには、表示するurlを入れればいいのですか?

No.
非同期通信は「バックグラウンド実行」という位置づけて考えて良いです。
つまり画面表示がありません。
「data を受け取って処理をするプログラム(今回はPython-Djangoでしょうか)が実行できるURL」を入れます。

1点ヒントを言っておくと、受け取り方は通常入力フォームから送信された場合と同じものであるはずです。
ただし返却する際はviewではなく、今回であればjson文字列を返却します。

二つ目jsonを送信する部分はどこになりますか。

1つ目のURLで実行する処理次第ではないでしょうか。ちょっと意味が分かりません。

単に「入力した情報をJSON化したい」のであれば、配列かオブジェクトに格納してJSON.parse()すればいいだけですし。前の質問から軽く見た感じでは迷走しているようにも見えます。
JSONファイルを作りたいのであればその実行先URLでJSONファイルを作って終わりです。

投稿2018/12/28 07:00

m.ts10806

総合スコア80850

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

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

退会済みユーザー

退会済みユーザー

2018/12/28 08:02

今下のサイトを参考にして、やっています。 https://qiita.com/juniskw/items/7fa72f91e3dc899a80ae 1のurlで指定することは出来たのですが、urlが変わりページが遷移してします。 2についてはまだ置いておくことにしています。 1についてですが、 views.pyにfor_viewがフォームを表示するページを表示して、for_ajaxがサーバ側に送られてきたデータに'!!!'をつけて返すと認識しています。 ここで、しかしfor_ajaxを動かすと元のページが表示されません。 どうしたらいいですか?
m.ts10806

2018/12/28 08:06

submit時に実行されるようになっているのでそうでしょうね。 preventDefaultを設定するか、 https://developer.mozilla.org/ja/docs/Web/API/Event/preventDefault submitボタンのtypeをbuttonに変更してclick時のイベントに変更してください。 というか今のコードから離れてませんか? あちこち参考にするのは良いですが、コードの方向性が散らばるのは解決には向かいませんよ。
退会済みユーザー

退会済みユーザー

2018/12/28 08:24

htmlの<input id="surprise_btn" type="submit"> をbuttonに変更しました。今度はページが遷移しなくなりました。views.pyのfor_ajaxが動いてないと思います。
m.ts10806

2018/12/28 08:30

ajaxは画面遷移させずに処理を行うものです。回答に「バックグラウンドで」と書いてますよ。
退会済みユーザー

退会済みユーザー

2018/12/28 08:36

ページが遷移しなかったのは良かったのですが、for_ajaxでコマンドにHelloと表示するようにしているのですが、表示しなかったのでfor_ajaxが動いていないと思うってことです。
m.ts10806

2018/12/28 08:39

バックグラウンド実行してるのにどうやってコマンド確認できるんですか? ajaxで指定した先の処理のデバッグするにはその処理でログファイルに書き出して実行後にログファイル確認するくらいしかないですよ。
退会済みユーザー

退会済みユーザー

2018/12/28 08:41

無事できました。 何度も何度もありがとうございました!!!
退会済みユーザー

退会済みユーザー

2018/12/28 08:43

コマンドプロンプトでdjangoのサーバ起動させると、そこに色々と情報が書かれて、そこにエラーとかも吐いているところに、djangoからprint()で表示させました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問