前提・実現したいこと
Djangoでデータベースの更新を行いたいです。
具体的に言うと、ブラウザ上で”+1”のボタンを押すとデータベース上でその数字が+1されその数字をブラウザ上に表示したいです。
例)元の数字が1→ボタンを押す→データベースが更新され1が2になる→2がブラウザ上に表示される。
3,4日詰まっているので答えていただけると嬉しいです。
至らない点を多いと思いますが、どうかよろしくお願いします。
発生している問題・エラーメッセージ
ボタンを押してもデータベース上では数字の更新後行われていない。
該当のソースコード
#blog/models.py
python
1from django.conf import settings 2from django.db import models 3from django.utils import timezone 4 5 6class Post(models.Model): 7 author = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE) 8 title = models.CharField(max_length=200) 9 10 #このup_numberをどうにかしたい 11 up_number = models.IntegerField(default=0) 12 13 published_date = models.DateTimeField(blank=True, null=True) 14 15 def publish(self): 16 self.published_date = timezone.now() 17 self.save() 18
#blog/urls.py
python
1from django.urls import path 2from . import views 3 4urlpatterns = [ 5 path('', views.post_list, name='post_list'), 6 path('post/<int:pk>/post_form/', views.post_form, name='post_form'), 7] 8 9
#blog/templates/blog/post_list.html
HTML
1{% for post in posts %} 2 <form action="{% url 'post_form' pk=post.pk %}" method="POST"> 3 {% csrf_token %} 4 <input type="submit" value="+1"> 5 </form> 6 <div> 7 <h5>{{ post.up_number }}</h5> 8 </div> 9{% endfor %} 10
#blog/views.py
python
1from django.shortcuts import render 2from django.utils import timezone 3from .forms import PostForm 4from .models import Post 5 6def post_list(request): 7 posts = Post.objects.filter(published_date__lte=timezone.now()).order_by('published_date') 8 return render(request, 'blog/post_list.html', {'posts': posts}) 9 10#分からないポイント 11def post_form(request): 12 13 if request.method == 'POST': 14 post = get_object_or_404(Post, pk=pk) 15 post.up_number += 1 16 post.save() 17 18 return render(request, 'blog/post_list') 19 20 21
補足情報(FW/ツールのバージョンなど)
OS Windows10
python 3.7.3
Django 2.2.6
回答1件
あなたの回答
tips
プレビュー