如何在Django中将基于函数的视图集成到基于类的视图中?

2024-09-28 20:58:31 发布

您现在位置:Python中文网/ 问答频道 /正文

在我的网站我有2个用户部分。用户发布页面和配置文件页面。简介页面上有他们的所有信息,所以用户名,描述,名字/姓氏等,而用户帖子页面上有他们的所有帖子。但是,我想把它们整合在一起。你知道吗

下面是一些代码。你知道吗

以下是用户帖子的视图

class UserPostListView(ListView):
    model = Post
    template_name = 'mainapp/user_posts.html'
    context_object_name = 'posts'

    def get_queryset(self):
        user = get_object_or_404(User,username=self.kwargs.get('username'))
        return Post.objects.filter(author=user).order_by('-published_date')

如您所见,我正在返回特定用户的帖子。你知道吗

现在是我的侧视图

def view_profile(request,pk=None):
        if pk:
            user_profile = User.objects.get(pk=pk)
        else:
            user_profile = request.user
        context = {'user':user_profile}
        return render(request,'mainapp/profile.html',context)

它返回用户的所有信息。你知道吗

下面是profile和user posts页面的HTML代码

{% block content %}


<div class="profile-page-container">

    <div class="profile-page-info">
<div class="profile-page-banner">
    <div class="profile-page-banner-background">
        <!-- <img src="https://cdn.pixabay.com/photo/2017/08/30/01/05/milky-way-2695569_960_720.jpg" alt="{{ user }}'s Background Image" > -->
    </div>
    <div class="profile-page-banner-text">
<h2 title="{{ user }}" id="username-profile-page">{{ user|safe|linebreaksbr|truncatechars_html:25 }} {% if user.userprofileinfo.verified %} <span class="image-profile-verified"><img draggable="false" title="Verified User" class="verifed" src="{% static 'images\verified.png' %}" alt="verified" width="25" height="25" srcset=""></span> {% endif %}</h2>

<p>{{ user.first_name }} {{ user.last_name }}</p><br>
</div>
</div>
<div class="profile-page-user-desc-box">
<p>{{ user.userprofileinfo.description }}</p>
<a href="{{ user.userprofileinfo.website }}"><p>{{ user.userprofileinfo.website }}</p></a>
<p>{{ user.userprofileinfo.joined_date |date:"F d Y" }}</p>
</div>
<br>
{% if user.userprofileinfo.image %}
<img class="rounded-circle account-img" src="{{ user.userprofileinfo.image.url }}" alt="{{ user }}'s Profile Picture'">
{% endif %}
</div>
<div class="user-post-user-profile-page">
    <h1 title="{{ user }}">Posts</h1>

{% for post in posts %}
<div class="content">
<div class="post">
        <h1 class='posttitle'>{{ post.title }}</h1>
        <img class="user-image" src="{{ post.author.userprofileinfo.image.url }}" alt="pfp" width="20%" height="20%">
                {% if post.published_date %}
                    <!-- <div class="postdate">
                        <i class="fas fa-calendar-day"></i> &nbsp; <p>Posted {{ post.published_date|timesince }} ago</p>
                    </div>   -->
                    <div class="posted-by">
                        <p>Posted by <strong>{{ post.author }}</strong>  {{ post.published_date|timesince }} ago</p>
                    </div>
                {% else %}
                    <a class="pub-post" href="{% url 'mainapp:post_publish' pk=post.pk %}">Publish</a>
                {% endif %}

              <p class='postcontent' >{{ post.text|safe|linebreaksbr }}</p>
                  </div>
                  </div>
{% endfor %}
</div>
</div>
{% endblock %}

这里是用户发布页面

{% block content %}
<div class="sidebar">
        <p class="active" href="#">{{ view.kwargs.username }}</p>
        <button class="commentbtn"><a class="aclass" href="#">Connect with {{ view.kwargs.username }}</a></button>
        <p>{{ user.userprofileinfo.email }}</p>
        <p>Lorem</p>
      </div>


{% for post in posts %}
<div class="content">
<div class="post">
        <h1 class='posttitle'>{{ post.title }}</h1>
        <img class="user-image" src="{{ post.author.userprofileinfo.image.url }}" alt="pfp" width="20%" height="20%">
                {% if post.published_date %}
                    <!-- <div class="postdate">
                        <i class="fas fa-calendar-day"></i> &nbsp; <p>Posted {{ post.published_date|timesince }} ago</p>
                    </div>   -->
                    <div class="posted-by">
                        <p>Posted by <strong>{{ post.author }}</strong>  {{ post.published_date|timesince }} ago</p>
                    </div>
                {% else %}
                    <a class="pub-post" href="{% url 'mainapp:post_publish' pk=post.pk %}">Publish</a>
                {% endif %}

              <p class='postcontent' >{{ post.text|safe|linebreaksbr }}</p>
                  </div>
                  </div>
{% endfor %}
{% endblock %}

我尝试将FBV合并到CBV中,方法是将其剪切并粘贴到get\u queryset方法下面,如下所示

def get_queryset(self):
    #... code here
def view_profile(request,pk=None):
    #... code here

然而,这并没有起作用。我只是好奇如何将两者结合在一起,这样我就能在一个地方拥有两个世界中最好的

编辑:这是模型




class UserProfileInfo(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE,max_length=30)
    first_name = models.CharField(max_length=50)
    last_name = models.CharField(max_length=50)
    description = models.CharField(max_length=150)
    website = models.URLField(max_length=200)
    image = ProcessedImageField(upload_to='profile_pics',
                                           processors=[ResizeToFill(150, 150)],
                                           default='default.jpg',
                                           format='JPEG',
                                           options={'quality': 60})
    joined_date = models.DateTimeField(blank=True,null=True,default=timezone.now)
    verified = models.BooleanField(default=False)


    def __str__(self):
        return f'{self.user.username} Profile'

    def save(self, *args, **kwargs):
        super().save(*args, **kwargs)

现在是邮报

class Post(models.Model):
    author = models.ForeignKey(User,related_name='posts',on_delete=models.CASCADE)
    title = models.CharField(max_length=75)
    text = models.TextField()
    group = models.ForeignKey(Group,null=True,blank=True,related_name='posts',on_delete=models.CASCADE)
    created_date = models.DateTimeField(default=timezone.now)
    image = models.ImageField(upload_to='post_images',blank=True,null=True)
    file = models.FileField(upload_to='post_files',blank=True,null=True)
    published_date = models.DateTimeField(blank=True,null=True,auto_now_add=True)
    comments_disabled = models.BooleanField(default=False)
    NSFW = models.BooleanField(default=False)
    spoiler = models.BooleanField(default=False)

    tags = TaggableManager()

    def __str__(self):
        return self.title


    def save(self, *args, **kwargs):
        super().save(*args, **kwargs)

Tags: nameimageselfdivtruedatemodelsdef
2条回答

同样是Ian answer的继续,如果你在模型之间有直接的关系,那么你可以简单地获得特定用户的帖子,如下所示:

def view_profile(request,pk=None):
        if pk:
            user_profile = User.objects.get(pk=pk)
            user_posts = Posts.objects.filter(user__id=pk)   #< -add these
        else:
            user_profile = request.user
            user_posts = Posts.objects.filter(user__id = request.user.id)   #< -add these
        context = {
                   'user':user_profile,
                   'user_posts':user_posts
                  }
        return render(request,'mainapp/profile.html',context)

用于获取用户的简单基于类的视图:

class UserDetailView(DetailView):
    model = User
    template_name = 'mainapp/profile.html'
    context_object_name = 'user'

关系(外键)可以向后跟随。每个外键都定义了一个反向关系(除非您将reverse_name设置为+…),它通常在外键引用的模型上命名为<modelname>_set

例如,以下两行是等效的

Post.objects.filter(author=user)
user.post_set.all()

这可以在您的配置文件模板中使用

{% for post in user.post_set.all %}
    ...
{% endfor %}

相关问题 更多 >