获取模板中所有自定义用户的列表(Django)

3 投票
2 回答
2734 浏览
提问于 2025-04-18 10:10

我定义了一个自定义的用户模型,现在运行得很好。但是在某个视图中,我想让用户列出所有注册的用户,但我似乎无法做到这一点。我希望能够在用于渲染视图的模板中访问所有用户,但我不知道从哪里开始。

这是我目前的进展——在使用原始用户模型时可以正常工作,但在我的自定义模型中却不行。

views.py

class UsersView(TemplateView):
    template_name = 'customer/users/users.html'

users.html

<h1>Users</h1>

<ul>
  {% for user in object_list %}
    <li class="user">{{ user }}</li>
  {% endfor %}
</ul>

urls.py

url(r'^customer/users/', views.UsersView.as_view(), name='users'),

models.py

class CustomUser(AbstractBaseUser):
    """
    Abstraction of a user.

    first_name - The first name of the user
    last_name - The last name of the user
    email - The email and username of the user
    project - The project that the user is part of
    is_active- Determines if the user is active, i.e. is the user "alive"
    is_project_admin - Determines if the user has access to the project admin views
    is_superuser - Determines if the user has full access to the entire database. Usually not.

    This model is used to store information about users.
    """

    first_name = models.CharField(max_length=200, blank=True, help_text="The first name of the user.")
    last_name = models.CharField(max_length=200, blank=True, help_text="The last name of the user.")
    email = models.EmailField(
        verbose_name='email address',
        max_length=255,
        unique=True,
        help_text="The email and username of the user. Required."
    )

    project = models.ForeignKey(Project, null=True, blank=True, help_text="The project that this user is part of.", related_name='users')

    is_active = models.BooleanField(
        default=True, 
        help_text="Determines whether the user is active or not. ",
        verbose_name="active"
    )
    is_project_admin = models.BooleanField(
        default=False, 
        help_text="Determines if the user has admin access in a project.",
        verbose_name="project admin"
    )
    is_superuser = models.BooleanField(
        default=False, 
        help_text="CAUTION - enabling this gives the user full admin access and access to the entire database. Only for ArcCore admins.",
        verbose_name="superuser"
    )

    objects = MyUserManager()

    USERNAME_FIELD = 'email'

    class Meta:
        verbose_name = 'user'
        verbose_name_plural = 'users'

    def get_full_name(self):
        #If the full name is not specified, return email
        if self.first_name == "" and self.last_name == "":
            return self.email
        else:
            return self.first_name + " " + self.last_name
    get_full_name.short_description = 'Name'

    def get_short_name(self):
        return self.first_name

    def __str__(self):
        return self.email

    def has_perm(self, perm, obj=None):
        "Does the user have a specific permission?"
        return True

    def has_module_perms(self, app_label):
        "Does the user have permissions to view the app `app_label`?"
        return True

    @property
    def is_staff(self):
        "Is the user a superuser?"
        return self.is_superuser

请忽略models.py中的任何糟糕代码,因为我对Python和Django都是新手,还没有开始重构。

有没有人知道如何在模板中列出我的所有用户?

提前谢谢大家!

2 个回答

0

我不明白这段代码怎么可能正常工作。你的视图是一个简单的模板视图,它从来没有做过任何事情来获取用户列表:这对默认的用户模型和你自定义的用户模型都是一样的。

你需要继承 ListView,而不是 TemplateView,并把 model 属性设置为你的用户类。

2

试试下面这个视图函数

class UsersView(TemplateView):
    template_name = 'customer/users/users.html'

    def get_context_data(self,**kwargs):
        context = super(UsersView,self).get_context_data(**kwargs)
        context['object_list'] = CustomUser.objects.all()
        return context

撰写回答