最近工作,所以想到我会提供一个解决方案的混合。首先,我使用RateIt,这是我认为是非常简单的设置,相当intuitve使用(*.js
和.*css
文件添加RateIt您base.html
模板):
http://www.radioactivethinking.com/rateit/example/example.htm
这里有关键件到我的解决方案:
urls.py
url(r'^object/rate/$', RateMyObjectView.as_view(), name='rate_my_object_view'),
my_template html的
<div class="rateit" data-rateit-resetable="false">Rate it!</div>
阿贾克斯。JS
$('.rateit').bind('click', function(e) {
e.preventDefault();
var ri = $(this);
var value = ri.rateit('value');
var object_id = ri.data('object_id');
$.ajax({
url: '/object/rate/?xhr',
data: {
object_id: object_id,
value: value
},
type: 'post',
success: function(data, response) {
console.log("ajax call succeeded!");
},
error: function(data, response) {
console.log("ajax call failed!");
}
});
});
一些视图比特是从詹姆斯贝内特(设定xhr
,例如):
http://www.b-list.org/weblog/2006/jul/31/django-tips-simple-ajax-example-part-1/
views.py
from django.views.generic.base import View
from .models import MyObject
class RateMyObjectView(View):
def post(self, request):
my_object = MyObject.objects.all().last()
xhr = 'xhr' in request.GET
star_value = request.POST.get('value', '')
my_object.score = star_value
my_object.save()
response_data = {
'message': 'value of star rating:',
'value': star_value
}
if xhr and star_value:
response_data.update({'success': True})
else:
response_data.update({'success': False})
if xhr:
return HttpResponse(json.dumps(response_data), content_type="application/json")
return render_to_response(self.template_name, response_data)
models.py
from django.db import models
class MyObject(models.Model)
score = models.FloatField(max_length=1, default=0)
请记住,这是一个天真的解决方案,并且只需替换对象列表中最后一项中的当前明星得分。这并不理想,因为将分数存储为自己的模型并链接到对象会更好。这是你可以存储他们,并做平均计算等。我现在正在处理这个问题,并在完成时更新这个答案。
谢谢。我已经把它全部整理好了。猜猜我只需要在整个AJAX事物中找到自己的头脑。 – 2011-02-13 03:44:45