Django ORM并在模板中显示多个字段

时间:2017-03-05 00:27:38

标签: python django model-view-controller orm jinja2

我在模板上显示多对多字段的数据时遇到问题。

我的模型看起来像这样:

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>

我如何做这个看似简单的任务?

1 个答案:

答案 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%}