网络编程
位置:首页>> 网络编程>> Python编程>> django ajax json的实例代码

django ajax json的实例代码

作者:q493383189  发布时间:2023-01-15 00:56:18 

标签:django,ajax,json

1. views.py

定义views视图函数,将数据存入字典。并用压缩为json格式,dumps,并return。


import json
def get_comments(request, article_id):
article_obj = models.Article.objects.get(id=article_id)
article_comments = article_obj.comment_set.select_related()
comment_dict = {}
for i in article_comments:
print('comments_id', i.id)
print('article_id', i.article_id)
print('parent_comment_id', i.parent_comment_id)
print('comment_type', i.comment_type)
print('user_id', i.user_id)
print('user_name', i.user.name)
print('comment', i.comment)
print('date', type(i.date))
print('date', time.strftime("%Y-%m-%d %H:%M:%S", i.date.timetuple()))
comment_dict[i.id] = [i.comment_type, i.comment, time.strftime("%Y-%m-%d %H:%M:%S", i.date.timetuple()), i.article_id, i.user_id, i.user.name, i.parent_comment_id]
comment_json = json.dumps(comment_dict)
return HttpResponse(comment_json)

2. article.html中编辑js jquery,接受json数据,并处理并添加到html中


<script>
function getComments() {
$.get("{% url 'get_comment' one_article.id %}", function(callback){
console.log(callback);
var obj = JSON.parse(callback);
console.log(this.comment_type);
for (var key in obj){
console.log(key);
console.log(obj[key])
}
}
function getCsrf() {
return $("input[name='csrfmiddlewaretoken']").val();
}
$(document).ready(function () {
$(".comment-box button").click(function () {
var comment_text = $('.comment-box textarea').val();
if (comment_text.trim().length < 5){
alert("评论不能少于5个字")
}else {
$.post(
 "{% url 'post_comment' %}",
 {
 'comment_type':1,
 article_id: "{{ one_article.id }}",
 parent_comment_id:null,
 'comment':comment_text.trim(),
 'csrfmiddlewaretoken':getCsrf()
 },
 function (callback) {
 console.log(callback);
 if (callback == 'post-comment-success'){
 alert('post-comment-success');
 getComments();
 }
 }
)
}
})
})
</script>

来源:https://blog.csdn.net/q493383189/article/details/75305347

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com