0

Djangoを使用していくつかの基本的なajaxを学習しようとしています。私の単純なプロジェクトはPrize、データベースで利用可能な賞品からランダムに選択し、その量を減らしprize.nameてページに戻るアプリです。

私はこれをやってのけるためにjQueryの$.ajaxメソッドを使用しています。error実行されているのは$.ajax呼び出しで定義された関数だけですが、エラーメッセージには「エラー」しか表示されません。私はajaxを初めて使用するので、おそらく明らかな何かを見落としています。関連するコードは次のとおりです。

モデル

class Prize(models.Model):
    name = models.CharField(max_length=50)
    quantity = models.IntegerField(default=0)

    def __unicode__(self):
        return self.name


URLConf

urlpatterns = patterns('',
    (r'^get_prize/$', 'app.views.get_prize' ),
)


意見

def get_prize(request):
    prizes = Prize.objects.filter(quantity__gt=0)
    to_return = {}

    if prizes:
            rand = random.randrange(len(prizes))
        prize = prizes[rand]
        prize.quantity -= 1
        prize.save()


        to_return['prize'] = prize.name
        data = simplejson.dumps(to_return)

        return HttpResponse(data, mimetype='application/json')


    else:
        to_return['msg'] = "That's all the prizes.  No more."
        data = simplejson.dumps(to_return)

        return HttpResponse(data, mimetype='application/json')


レンプレート

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>User's Conference Prize Randomizer</title>
<link rel="stylesheet" type="text/css" href="/static-media/style.css" />
<script type="text/javascript" src="/static-media/jquery-1.2.6.min.js"></script>

<script type="text/javascript">
    var get_prize = function() {
        var args = { 
            type: "GET",
            url: "get_prize",
            dataType: "json",
            success: done,
            error: function(response,error_string,e){
                alert( "Error: " + response.responseText + " " + error_string ); 
                for (i in e){
                    alert(i);
                }
            }
        };

        $.ajax(args);
    };

    var done = function(response) {
        if(response)    {
            alert(response);
        }

        else {
            alert("Something boo-booed");
        }
    };

    $(document).ready(function() {
       $("#start").click(get_prize);
     });
</script>

</head >

<body>
        <p><a href="" id='start'>Get Prize</a>, this link isn't working how I'd like.</p>

</body>

4

3 に答える 3

1

これはあなたの質問と正確には関係ありませんが、データベースからランダムなオブジェクトをフェッチしようとしている場合は、代わりにこれを行うことができます。

prize = Prize.objects.filter(quantity__gt=0).order_by('?')[:1]
if prize:
    prize = prize[0]

# Using a slice prevents an exception if the query returns an empty queryset.
# If you're not a fan of LBYL, you could wrap the query in a try...except block instead:

try:
    prize = Prize.objects.filter(quantity__gt=0).order_by('?')[0]
except IndexError:
    # No more prizes pal...done, fini.
于 2009-05-11T20:57:04.510 に答える
0

これはあなたの質問に対する直接の答えではありませんが、jQueryタコナイトプラグインを見たことがありますか?これにより、ほとんどのAJAXyの作業は簡単になります。マラップのタコナイトページの詳細。あなたがそれにいる間、彼の他の優れたプラグインをチェックしてください。

于 2009-05-11T16:33:17.843 に答える
0

やれやれだぜ。return falseajax呼び出しを行った関数を省略したところです。n00bに行く方法。:0。

于 2009-05-11T20:05:29.510 に答える