我在模板上显示多对多字段的数据时遇到问题。
我的模型看起来像这样:
class User(models.Model):
first_name = models.CharField(max_length=100)
last_name = models.CharField(max_length=100)
email = models.EmailField()
password = models.CharField(max_length=255)
class Secret(models.Model):
message = models.TextField(max_length=1000)
posted_by = models.ForeignKey(User)
all_likes = models.ManyToManyField(User, related_name="all_users")
objects = SecretManager()
当用户点击“赞”按钮时,用户通过all_likes字段与该秘密相关联。
在我的模板中,我显示所有机密,如果会话ID等于posted_by用户ID,则显示“删除”按钮。现在我要做的就是添加文本“你喜欢这个”,如果秘密的all_likes包含用户,但我正在做的事情是对的。
<table>
{% if secrets %}
{% for secret in secrets %}
<tr>
<td>{{secret.message}}</td>
<td>{{secret.created_at}}</td>
{% if request.session.id == secret.posted_by.id %}
<td>You posted this</td>
<td> <form action="{%url 'secrets:delete_secret' id=secret.id %}" method="POST">
{% csrf_token %}
<input type="submit" name="delete" value="delete">
</form>
{% endif %}
{% if request.session.id != secret.posted_by.id %}
<td> <form action="{%url 'secrets:create_like' user_id=request.session.id secret_id=secret.id %}" method="POST">
{% csrf_token %}
<input type="submit" name="Like" value="Like">
</form>
{% endif %}
////HERE I WANT TO ADD LOGIC TO DiSPLAY "YOU LIKED THIS" IF REQUEST.SESSION.ID IS EQUAL TO SECRET.ALL_LIKES.USER.ID////
</td>
</tr>
{% endfor %}
{% endif %}
</table>
我如何做这个看似简单的任务?
答案 0 :(得分:0)
在Secret类中添加自定义方法并将其作为属性装饰,如下所示
@property
def all_like_ids(self):
return [x.id for x in self.all_likes]
然后在你的模板中执行:
{%if request.session.id in secret.all_like_ids %}
{%endif%}