我有一个可以正常工作的表单,但现在我尝试将其转换为 Ajax 后无法正常工作。我收到 500 错误。有任何想法吗?
初始表单 HTML
<form method="post">
{% csrf_token %}
<input type='hidden' name='entry_id' value='{{ e.id }}'>
<input type='hidden' name='project_id' value='{{ project.id }}'>
<input type='hidden' name='team_id' value='{{ t.id }}'>
{% get_vote_status request=request project=project entry=e.entry %}
</form>
上面使用的模板标签
@register.simple_tag
def get_vote_status(request, project, entry):
user = request.user
determined_vote_status = False
try:
for v in user.userprofile.votes.all():
if v.entry == entry:
determined_vote_status = True
return '''<button type="submit" name="remove_vote" value="Remove Vote" class="votingbutton"><img src="/static/bootstrap/img/checked.png" alt="Voted" class="check-button"></button>'''
if determined_vote_status is False:
return '''<button type="submit" name="add_vote" value="Add Vote" class="votingbutton"><img src="/static/bootstrap/img/check.png" alt="Voted" class="check-button"></button>'''
except:
pass
更新了 Ajax HTML
<script type="text/javascript">
$(document).ready(function() {
var csrftoken = $.cookie('csrftoken');
function csrfSafeMethod(method) {
// these HTTP methods do not require CSRF protection
return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
}
$.ajaxSetup({
crossDomain: false, // obviates need for sameOrigin test
beforeSend: function(xhr, settings) {
if (!csrfSafeMethod(settings.type)) {
xhr.setRequestHeader("X-CSRFToken", csrftoken);
}
}
});
$("#button{{ forloop.counter }}").click(function() {
var $url = "/craig-test/testing-craig/6/5/";
var $type = "POST";
var $dataType = "json";
var $data = {
'entry_id': {{ e.id }},
'project_id': {{ project.id }},
'team_id': {{ t.id }},
csrfmiddlewaretoken: csrftoken
};
$data = JSON.stringify($data);
$.ajax({
url : $url,
type : $type,
dataType: $dataType,
data : $data,
success : function(json) {
console.log("+1");
},
error : function(xhr,errmsg,err) {
console.log(errmsg, err);
}
});
return false;
});
});
</script>
<form method="post" name="vote form" >
{% csrf_token %}
<input type='hidden' name='entry_id' value='{{ e.id }}'>
<input type='hidden' name='project_id' value='{{ project.id }}'>
<input type='hidden' name='team_id' value='{{ t.id }}'>
<input id="button{{ forloop.counter }}" type="button" value="send to server"></input>
</form>
视图.py
@login_required(login_url='/accounts/login/')
def projects(request, teamslug, projectslug,
teamid, projectid, template_name='projects.html'):
teams = Team.objects.all()
projects = Project.objects.all()
userprofile = UserProfile.objects.all()
votes = Vote.objects.all()
user = request.user
for p in user.userprofile.projects.all():
sluglist.append(p.slug)
if projectslug in sluglist:
if request.is_ajax():
raise ValueError("tktktkt")
网址.py
url(r'^(?P<teamslug>[^\.]+)/(?P<projectslug>[^\.]+)/(?P<teamid>[^\.]+)/(?P<projectid>[^\.]+)/$', 'ideas.views.projects', name='project_url')