Как отобразить список пользователей, которым понравился пост в приложении Flask? - PullRequest
1 голос
/ 28 апреля 2020

Я новичок в Flask, и я создал блог социальной сети, используя Flask, следуя видео Кори Шафера и Мигеля Гринберга, я включил дополнительные функции, такие как лайк пост и комментирование поста. Все функции, которые я включил, функционируют должным образом, но я не могу просматривать пользователей, которым понравилась публикация.

Здесь находится мой файл rout.py, имеющий значение like и маршрут ViewLikers

@app.route('/like/<int:post_id>/<action>')
@login_required
def like_action(post_id, action):
    post = Post.query.filter_by(id=post_id).first_or_404()
    if action == 'like':
        current_user.like_post(post)
        db.session.commit()
    if action == 'unlike':
        current_user.unlike_post(post)
        db.session.commit()
    return redirect(request.referrer) 

@app.route('/like/<int:post_id>/viewLikes')
@login_required
def viewLikers(post_id):
    post = Post.query.get_or_404(post_id)
    return render_template('viewLikes.html', likers=post.get_likers())

Вот мой файл models.py

class PostLike(db.Model):
    __tablename__ = 'PostLike'
    id = db.Column(db.Integer, primary_key=True)
    users_id = db.Column(db.Integer, db.ForeignKey('user.id'))
    post_id = db.Column(db.Integer, db.ForeignKey('post.id'))

class User(db.Model, UserMixin):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(20), unique=True, nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)
    image_file = db.Column(db.String(20), nullable=False, default='default.jpg')
    password = db.Column(db.String(60), nullable=False)
    posts = db.relationship('Post', backref='author', lazy=True)

    followed = db.relationship(
        'User', secondary=followers,
        primaryjoin=(followers.c.follower_id == id),
        secondaryjoin=(followers.c.followed_id == id),
        backref=db.backref('followers', lazy='dynamic'), lazy='dynamic')

    liked = db.relationship(
        'PostLike',
        foreign_keys='PostLike.users_id',
        backref='user', lazy='dynamic')

    def like_post(self, post):
        if not self.has_liked_post(post):
            like = PostLike(users_id=self.id, post_id=post.id)
            db.session.add(like)

    def unlike_post(self, post):
        if self.has_liked_post(post):
            PostLike.query.filter_by(
                users_id=self.id,
                post_id=post.id).delete()

    def has_liked_post(self, post):
        return PostLike.query.filter(
            PostLike.users_id == self.id,
            PostLike.post_id == post.id).count() > 0  

class Post(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(100), unique=True, nullable=False)
    date_posted = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
    content = db.Column(db.Text, nullable=False)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)

    likes = db.relationship('PostLike', backref='post', lazy='dynamic')
    comments = db.relationship('Comment', backref='title', lazy='dynamic')


    def get_likers(self):
        return PostLike.query.filter_by(users_id =User.id, post_id=self.id)

Но когда я нажимаю на кнопку viewLikes в шаблоне, появляется сообщение об ошибке Function doesn't return any view

1 Ответ

1 голос
/ 28 апреля 2020

Простая ошибка. В последнем методе вы не вернули render_template. return render_template('')

Также позвоните .first() на ваш почтовый объект

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...