2

投稿データをフォームに送信するのを手伝ってくれませんか。ここに私が持っているもの: モデル:

class Test (models.Model):
    text    = models.TextField(blank=True, max_length=300)

ビュー:

def post_test(request):
    print 'aesewewewew'
    if request.is_ajax():
        print 'ajax'
        form = TestForm(request.POST)
        if form.is_valid():
            form.save()
            return HttpResponse('success')
        else:
            return HttpResponse('failed')
    else:
        print 'aaaaa'

テンプレート:

<div id="post"></div>
<a href="/" onclick=click()>Post</a>
<script>
function click(){
    $.post("/post", {
        text: "eqweqeqeqweqw"
    },
    function(data) {
        alert(data);
    }
)};

URL:

(r'^post','test_propject.main.views.post_test'),

形:

class TestForm (forms.ModelForm):
    class Meta:
        model = Test

それは私にはうまくいきません。ここでエラーが見つかりません。おそらく作業コードへのリンクを教えてください。Get リクエストは正常に機能します。モデルから作成された単純なフォームを作成し、ページをリロードせずに ajax 経由でデータを送信する何らかの方法が存在する可能性があります。

ありがとうございました

4

2 に答える 2

3

これを試して :

def post_test(request):
    if request.method == 'POST':
        form = TestForm(request.POST)
        if form.is_valid():
            form.save()
            return HttpResponse('success')
        else:
            return HttpResponse('failed')  

上記を実装する前に、ここでチュートリアルを学習することを強くお勧めします..

編集: urls.py は次のようになります。

from django.conf.urls.defaults import *
from test_project.main.views import post_test

urlpatterns = patterns('',
  url(r'^post/$', post_test, name = 'post_test'),
)

そしてあなたのテンプレート:

<script>
function click(){
    $.post('{% url post_test %}', {
        text: "eqweqeqeqweqw"
    }
)};
</script>

{% url post_test %} は、外部の js ファイルでは機能しないことに注意してください。

于 2011-04-28T04:45:16.360 に答える
0

私の主な問題は私の脳でした)。含めるのを忘れました:

<script type="text/javascript">
        $('html').ajaxSend(function(event, xhr, settings) {
            function getCookie(name) {
                var cookieValue = null;
                if (document.cookie && document.cookie != '') {
                    var cookies = document.cookie.split(';');
                    for (var i = 0; i < cookies.length; i++) {
                        var cookie = jQuery.trim(cookies[i]);
                        // Does this cookie string begin with the name we want?
                        if (cookie.substring(0, name.length + 1) == (name + '=')) {
                            cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
                            break;
                        }
                    }
                }
                return cookieValue;
            }
            if (!(/^http:.*/.test(settings.url) || /^https:.*/.test(settings.url))) {
                // Only send the token to relative URLs i.e. locally.
                xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken'));
            }

        });
    </script>
于 2011-05-03T20:40:53.867 に答える