Пытаюсь внедрить систему начисления баллов в моем геймифицированном веб-приложении

#flask #web-applications

#flask #веб-приложения

Вопрос:

Итак, у меня есть страница упражнений в моем веб-приложении flask. У каждого упражнения будет кнопка «завершить». При нажатии кнопки «Готово» я хочу начислить баллы пользователю, вошедшему в систему в данный момент. Затем очки будут добавлены в индикатор выполнения пользователя для повышения уровня. Я просто хочу получить общее представление о том, как это сделать.

Это моя пользовательская модель в базе данных

 class User(UserMixin, db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(64), index=True, unique=True)
    email = db.Column(db.String(120), index=True, unique=True)
    password_hash = db.Column(db.String(128))
    points = db.Column(db.Integer)
  

Это HTML-файл, в котором за нажатие кнопки будут начисляться очки

 <a data-toggle="collapse" class="w3-large" href="#tip4" onclick="getPoints()">...</a>
  

Это функция получения баллов

 <script>
function getPoints(){
  points  = 20; #How do i access the database.points in this case?
}
</script>
  
 @bp.route('/register', methods=['GET', 'POST'])
def register():
    if current_user.is_authenticated:
        return redirect(url_for('main.index'))
    form = RegistrationForm()
    if form.validate_on_submit():
        user = User(username=form.username.data, email=form.email.data)
        user.set_password(form.password.data)
        user.points = 0
        db.session.add(user)
        db.session.commit()
        flash('Congratulations, you are now a registered user!')
        return redirect(url_for('auth.login'))
    return render_template('auth/register.html', title='Register', form=form)
  
 @bp.route('/activity1')
@login_required
def activity1():
    return render_template('activity1.html', title='Activity 1')
  

Это в основном то, что у меня есть для python. Activity1.html вот где я хочу иметь возможность получать очки.

Комментарии:

1. Как насчет вызова функции при нажатии кнопки и добавления баллов к счетчику и сохранения / обновления его в базе данных? У вас уже есть какой-либо код для показа, какие-либо конкретные трудности, с которыми вам нужна помощь?

2. @gittert Я добавил некоторый код выше. Как мне увеличить количество баллов в базе данных.

3. Можете ли вы показать код python?

4. @gittert Я добавил немного кода на python выше. В основном она состоит из базовой настройки входа / регистрации в flask и маршрутизации. В остальном я там мало что сделал.

Ответ №1:

Взгляните на этот код. Это непроверено, но я уверен, что вы поняли суть (каламбур ;)). Не забудьте изменить шаблон activity1 и добавить туда переменную points. Если вы используете этот код, я бы посоветовал удалить из него скрипт javascript getpoints.

 @bp.route('/activity1', methods=['GET', 'POST'])
@login_required
def activity1():
    user = User.query.filter_by(username = username).first()
    points = user.points

    if request.method == 'POST':
        user = User.query.filter_by(username = username).first()
        points  = user.points   20
        user.points = points
        db.session.commit()
        flash('Congratulations, you have earned 20 points!')

    return render_template('activity1.html', 
            title = 'Activity 1',
            points = points,
            )