Djangoの処理結果をJavascriptでalert表示させています。
ファイルアップロード処理を行い、処理結果を表示させているのですが、表示が1動作遅れてきます。
やりたいこと
python manage.py runserverを行い、local hostにアクセスする。
ファイルを選択し、アップロード処理を呼ぶ。Djangoでファイル選択有無を判定する。ファイルが選択されていればアップロード処理を呼び出し、処理が正常に終了すれば「完了」メッセージを表示し、ファイルが選択されていなければ「ファイルを選択してください」メッセージを表示させます。
現状の動作
local hostにアクセスし、初期表示を行う。
1回目
ファイルを選択し、アップロード処理を呼び出す(POSTする)。viewsで判定し、ファイルが選択されていて、アップロード処理が呼ばれる(ファイルがアップロードされる)。
「完了」メッセージをrequestに書き出す。
Javascriptでalert('{{message}}')を行っているが、アラートが発生しない
2回目
ファイルを選択せず、アップロード処理を呼び出す(POSTする)。viewsで判定し、ファイルが選択されておらず、「ファイルを選択してください」メッセージをrequestに書き出す。
Javascriptでalert('{{message}}')を行うと、「完了」メッセージが呼ばれる。
試したこと
複数サイトを検索し、messages.info, messages.errorについて調査しましたが、原因が分かりません。
またmessages.info, messages.errorをpython側でデバッグを試みましたが、それも上手くいきません。
ソースは以下の通りです。
template(index.html)
1{% load static %} 2<!DOCTYPE html> 3<html lang="ja"> 4 <head> 5 <!-- 略 --> 6 </head> 7 <body> 8 <form action="" method="post" name="form1" enctype="multipart/form-data"> 9 <input type="file" id="files" name="files" accept=".xlsx" multiple > 10 <button class="button2" type="button" id='upload_files' onclick=filesUpload()>取り込み実行</button> 11 </form> 12 13 <script> 14 // ファイルアップロード処理よびだし 15 function filesUpload () { 16 {% for message in messages %} 17 alert('{{ message }}'); 18 {% endfor %} 19 }; 20 </script> 21 </body> 22</html>
python(django
1from django.contrib import messages 2 3def index(request): 4 5 postdata = request.POST 6 7 if request.method == 'POST': 8 9 # ファイル選択判定処理 10 if len(request.FILES.getlist('files')) == 0: 11 # ファイル未選択 12 messages.error(request, "ファイルを選択してください。") 13 return render(request, 'app/index.html', context) # contextには適切な値(辞書)が入力されている 14 15 else: 16 # ファイル選択 17 for i in range(len(request.FILES.getlist('files'))): 18 19 # 略 20 21 # アップロード処理呼び出し 22 23 # アップロード処理正常終了 24 25 messages.info(request, "完了") 26 27 return render(request, 'app/index.html', context) 28
どうかご助言をお願いします。
あなたの回答
tips
プレビュー