2017-01-29 7 views
0
<form id="searchform"> 
    {% csrf_token %} 
    <div class="col-md-8"> 
     <input type="text" id="question" class="form-control" placeholder="question......" 
     name="question"> 
    </div> 
    <div class="col-md-2"> 
     <input class="btn btn-primary" type="submit" value="ASK"> 
    </div> 
<form> 

私は、このテンプレートを取得し、データがジャンゴAJAXリクエストは、データ

<script type="text/javascript"> 
$("document").ready(function(){ 
    $("#searchform").submit(function() { 
     $.ajax({ 
      type: "POST", 
      url : "results", 
      data:{ 
       input:$("#question").val(), 
       csrfmiddlewaretoken: '{{ csrf_token }}' 
      }, 
      success : function(data){ 
       $('#answer').html(data); 
      } 
     },"json"); 
    }); 
}); 
</script> 

表示する得るために、AJAXリクエストを怒鳴るとビューが

def results(request): 
    if request.method == "POST": 
     resource = request.POST['input'] 
    return render(request, 'index.html',{"resource" : resource}) 

の下に、私は形でsumbitものですいけないことができますurl.butにはテンプレートで結果が表示されません。このコードの問題は何ですか?ありがとうございます。

答えて

0

私はあなたがこのコードを書いて見る方法を参照して問題がいくつかあります。フォーム提出を喜ばせることは簡単で、非常にエレガントに行うことができます。

あなたが共有したコードに基づいて説明しましょう。

まず、フォームにはアクションと方法がありません。適切に定義されたフォームは、ブラウザがjavascriptをサポートしていない場合でも動作するはずです。

フォームフォームフィールドの1つに名前パラメータがありません。

<form id="searchform" method="POST" action="{% url 'results' %}"> 
    {% csrf_token %} 
    <div class="col-md-8"> 
     <input type="text" id="question" name="input" class="form-control" placeholder="question......" 
     name="question"> 
    </div> 
    <div class="col-md-2"> 
     <input class="btn btn-primary" type="submit" value="ASK"> 
    </div> 
<form> 

あなたのjavascriptでは、オーバーライドを追加してデフォルト動作を防止するだけです。これはあなたのページがちょうどURLを変えている理由です。

より一般的なバージョンです。データペイロードなどを構成する必要はありません。

$(document).on('submit', "#searchform", function (event) { 
    event.preventDefault(); 
    var ele = $(this); 
    $.ajax({ 
    type: ele.attr("method"), 
    url: ele.attr("action"), 
    data: ele.serialize(), 
    success: function (data) { 
     $('#answer').html(data); 
    } 
    }); 
}); 

あなたの意見には問題はありません。

+0

それは働いています。 – KHK

0

あなたのビューでJsonResponse対象:

from django.http import JsonResponse 

def results(request): 
    if request.method == "POST": 
     resource = request.POST['input'] 
    return JsonResponse({"resource" : resource}) 
+0

それはURLでdata.but印刷does notのそれは中に私は、あなたのJavaScriptでテンプレート – KHK

+0

内のデータを印刷したい入力しdata.Andを示して - これを修正し、あなたのコードを動作させるために '成功'関数は、次のように追加します: '$( '#answer').html(data.resource);' – afilardo

+0

まだ動作しません:( – KHK

0

あなたのフォームは、GETメソッドとGETパラメータ(フォームのデフォルト動作)を介して送信されます。単にそのデフォルトの動作を妨げる

$("#searchform").submit(function(event) { 
    event.preventdefault(); 
    ... 
}