gpt4 book ai didi

javascript - ajax 未激活,将我带到另一个页面

转载 作者:行者123 更新时间:2023-11-30 06:15:20 25 4
gpt4 key购买 nike

该代码按我的意愿运行,但它会将我带到另一个页面并显示类似 {"success": 1, "voteobj": 57} 的内容。我被告知 ajax 是用于此目的的工具,但我并不擅长它。这就是我所拥有的。有人可以检查我在哪里犯了错误以及我应该如何修复它/?

<script type="text/javascript">
jQuery(document).ready(function($)
{
$(".vote_form").submit(function(e)
{
e.preventDefault();
var btn = $("button", this);
var l_id = $(".hidden_id", this).val();
btn.attr('disabled', true);
$.post("vote/", $(this).serializeArray(),
function(data) {
if(data["voteobj"]) {
btn.text("-");
}
else {
btn.text("+");
}
});
btn.attr('disabled', false);
});
});
</script>
<script
src="https://code.jquery.com/jquery-3.4.1.js"
integrity="sha256-WpOohJOqMqqyKL9FccASB9O0KwACQJpFTUBLTYOVvVU="
crossorigin="anonymous"></script>


<form method="post" action="{% url 'vote' %}" class="vote_form">
<li> [{{ post.votes }}]
{{post}}
{% csrf_token %}
<input type="hidden" id="id_post" name="post" class="hidden_id" value="{{ post.pk }}" />
<input type="hidden" id="id_voter" name="voter" class="hidden_id" value="{{ user.pk }}" />
{% if not user.is_authenticated %}
<p>login to vote</p>

{% elif post.pk not in voted %}
<button class="btn btn-primary">like</button>
{% else %}
<button class="btn btn-primary">dislike</button>
{% endif %}
</form>

下面是我的python代码

class JSONFormMixin(object):
def create_response(self, vdict=dict(), valid_form=True):
response = HttpResponse(json.dumps(vdict), content_type='application/json')
response.status = 200 if valid_form else 500
return response

class VoteFormBaseView(FormView):
form_class = VoteForm

def create_response(self, vdict=dict(), valid_form=True):
response = HttpResponse(json.dumps(vdict))
response.status = 200 if valid_form else 500
return response

def form_valid(self, form):
post = get_object_or_404(Post, pk=form.data["post"])
user = self.request.user
prev_votes = Vote.objects.filter(voter=user, post=post)
has_voted = (len(prev_votes) > 0)

ret = {"success": 1}
if not has_voted:
# add vote
v = Vote.objects.create(voter=user, post=post)
ret["voteobj"] = v.id
else:
# delete vote
prev_votes[0].delete()
ret["unvoted"] = 1
return self.create_response(ret, True)


def form_invalid(self, form):
ret = {"success": 0, "form_errors": form.errors }
return self.create_response(ret, False)



urls.py

urlpatterns = [
path('vote/', auth(VoteFormView.as_view()), name='vote'),

编辑:我按照以下网站上的说明进行操作:https://arunrocks.com/building-a-hacker-news-clone-in-django-part-4/

一切正常,但 ajax 在我这边

编辑:所以如果没有 ajax,url 是 http://127.0.0.1:8000/community/vote/使用ajax,网址是/社区/帖子/3/投票/但它说 Not Found: on terminal

最佳答案

 return self.create_response(ret, True) 

应该是

return JsonResponse(safe=False, ret)

不好意思,我没抓紧时间偷懒回答。不要改变回应。保持原样,然后执行我刚才在上面所做的操作。

应该可以。

关于javascript - ajax 未激活,将我带到另一个页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56517491/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com