大佬教程收集整理的这篇文章主要介绍了从 views.py 获取 JSON 格式的当前登录用户,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试构建一个关注和取消关注按钮,我只想显示该按钮对于已登录的任何其他用户,用户不应能够关注自己。
如何从我的 vIEws.py 将当前登录的用户作为 JsON 格式返回到我的 Js 文件? 我在 JavaScript 文件中而不是在模板中构建按钮,我尝试以 JsON 格式返回但没有成功
vIEws.py
def display_profile(request,profilE):
try:
profile_to_display = User.objects.get(username=profilE)
profile_to_display_ID = User.objects.get(pk=profile_to_display.ID)
except User.DoesnotExist:
return JsonResponse({"error": "Profile not found."},status=404)
# Return profile contents
if request.method == "GET":
return JsonResponse(profile_to_display.profile.serialize(),safe=falsE)
else:
return JsonResponse({
"error": "GET or PUT request required."
},status=400)
@H_68_2@models.py
from django.contrib.auth.models import AbstractUser
from django.db import models
class User(AbstractUser):
pass
class NewPost(models.Model):
poster = models.ForeignKey("User",on_delete=models.PROTECT,related_name="posts_posted")
description = models.TextFIEld()
date_added = models.datetiR_557_11845@eFIEld(auto_Now_add=TruE)
likes = models.IntegerFIEld(default=0)
def serialize(self):
return {
"ID": self.ID,"poster": self.poster.username,"description": self.description,"date_added": self.date_added.strftime("%b %d %Y,%I:%M %p"),"likes": self.likes
}
class Profile(models.Model):
user = models.OnetoOneFIEld(User,on_delete=models.CASCADE)
following = models.ManyToManyFIEld(User,blank=True,related_name="following")
followers = models.ManyToManyFIEld(User,related_name="followers")
def serialize(self):
return {
"profilEID": self.user.ID,"following": int(self.following.all().count()),"followers": int(self.followers.all().count()),}
index.Js
function load_user_info(user_clicked_on){
document.querySELEctor('#page-vIEw').style.display = 'none';
document.querySELEctor('#posts-vIEw').style.display = 'none';
document.querySELEctor('#show-posts').style.display = 'none';
document.querySELEctor('#load-profile').style.display = 'block';
fetch(`/profile/${user_clicked_on}`)
.then(response => response.Json())
.then(profile => {
const profile_element = document.createElement('div');
const followers = document.createElement('div');
const following = document.createElement('div');
const follow_button = document.createElement('button');
followers.INNERHTML = 'Followers: ' + profile.followers;
following.INNERHTML = 'Following: ' + profile.following;
if (profile.profilEID == ?? ){
follow_button.INNERHTML = 'Sameuser';
}else{
follow_button.INNERHTML = 'Not same user';
}
profile_element.appendChild(followers);
profile_element.appendChild(following);
profile_element.appendChild(follow_button);
profile_element.classList.add('profile_element');
document.querySELEctor('#user-profile').appendChild(profile_element);
});
document.querySELEctor('#user-profile').INNERHTML = `<h3>${user_clicked_on.charat(0).toupperCase() + user_clicked_on.slice(1)} Profile</h3>`;
}
我认为您只需要登录用户的详细信息,对吗? 也许您可以使用
从请求对象中获取它{{request.user}}
这将返回登录的用户实例
{{request.user.usernamE}} {{request.user.email}}
这将返回用户名和电子邮件
我不知道您是否可以直接在 javascript 中使用它,但是您可以使用隐藏字段将其保存在模板中
<input type="hidden" value="{{request.user.usernamE}}" id='user_detail'>
并使用 id 选择器(getElementById 或 jquery)获取它
$('#user_detail').val()
以上是大佬教程为你收集整理的从 views.py 获取 JSON 格式的当前登录用户全部内容,希望文章能够帮你解决从 views.py 获取 JSON 格式的当前登录用户所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。