質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

2602閲覧

login_requiredを消すと、'AnonymousUser' object is not iterableが、入れると、object has no attribute 'user'が発生する

reol-777

総合スコア14

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/01/08 06:05

現在、todoアプリを作っていて、ユーザーがログインしてきたら、そのユーザーのtodoリストのみ表示されるような機能を実装しています。機能自体はほぼ完成に近いのですが、エラーが発生します。ご教授お願いします。

↓以下発生するエラー
・viewの中のget_querysetの前に@login_required()を入れると、AttributeError at /list/
'TodoList' object has no attribute 'user'が発生する。

・@login_required()を消すと、ログインユーザーのtodoリストのみ表示されるようになるが、ログアウトすると、'AnonymousUser' object is not iterableが発生する。

↓以下各コード(一部抜粋)

view

1class TodoList(FilterView): 2 template_name = 'list.html' 3 model = TodoModel 4 context_object_name = "lists" 5 @login_required() 6 def get_queryset(self): 7 return TodoModel.objects.filter(user=self.request.user)

model

1from django.db import models 2from django.utils import timezone 3from django.contrib.auth.models import User 4# Create your models here. 5class Category(models.Model): 6 class Meta: 7 db_table = "category" 8 verbose_name = "カテゴリ" 9 verbose_name_plural = "カテゴリ" 10 11 category_name = models.CharField(max_length=255,unique=True,verbose_name="カテゴリの名前",null=True) 12 13 def __str__(self): 14 return self.category_name 15 16PRIORITY = (('danger','high'),('info','normal'),('success','low')) 17class TodoModel(models.Model): 18 class Meta: 19 db_table = "todomodel" 20 verbose_name = "todoモデル" 21 verbose_name_plural = "todoモデル" 22 23 title = models.CharField(max_length=100,verbose_name="タイトル") 24 memo = models.TextField(verbose_name="メモ") 25 priority = models.CharField( 26 max_length = 50, 27 choices = PRIORITY, 28 verbose_name="優先度" 29 ) 30 duedate = models.DateTimeField(verbose_name="期日",default=timezone.now) 31 category = models.ForeignKey(Category,on_delete = models.PROTECT,verbose_name="カテゴリ",null=True) 32 user = models.ForeignKey(User,on_delete = models.PROTECT,verbose_name='ユーザー',default = 1) 33 def __str__(self): 34 return self.title 35

html

1{% extends 'base.html' %} 2{% block content %} 3{% for item in lists %} 4 <div class="alert alert-{{ item.priority }}" role="alert"> 5 <!-- 完了ボタン --> 6 <a href="#" class="btn-circle-3d"></a> 7 <div class="item_object">TITLE:{{ item.title}} LIMIT:{{ item.duedate|date:"Y-m-d H:i" }} CATEGORY:{{ item.category }} USER:{{item.user}}</div> 8 <a data-toggle="modal" data-target="#DetailModal{{ item.pk }}" class="btn2 btn--detail btn--circle btn--shadow--a" tabindex="-1" role="button" aria-disabled="true"><i class="fas fa-eye fa-3x" data-fa-transform="shrink-8 up-5 left-1.05"></i></a> 9 <a data-toggle="modal" data-target="#DeleteModal{{ item.pk }}" class="btn2 btn--delete btn--circle btn--shadow--a" tabindex="-1" role="button" aria-disabled="true"><i class="fas fa-trash-alt fa-3x" data-fa-transform="shrink-8 up-5 right-1.1"></i></a> 10 <a href="{% url 'update' item.pk %}" class="btn2 btn--update btn--circle btn--shadow--a" tabindex="-1" role="button" aria-disabled="true"><i class="fas fa-pen-fancy fa-3x" data-fa-transform="shrink-8 up-5"></i></a> 11 </div> 12{% empty %} 13 <li class="list-group-item"> 14 対象のデータがありません 15 </li> 16 {% endfor %} 17</div> 18<!-- ページネーション読み込み --> 19 {% include "./pagination.html" %} 20{% endblock content %} 21

base

1<body> 2{% if user.is_authenticated %} 3 {% block content %} 4 {% endblock content %} 5 {% endif %} 6</body>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

色々調べてこのようにしたらうまくいきました

view

1class TodoList(FilterView): 2 template_name = 'list.html' 3 model = TodoModel 4 context_object_name = "lists" 5 6 def get_queryset(self): 7 if self.request.user.is_active: 8 return TodoModel.objects.filter(user=self.request.user) 9 else: 10 return TodoModel.objects.none() 11 12class TodoCreate(LoginRequiredMixin,CreateView): 13 template_name = 'create.html' 14 model = TodoModel 15 form_class = TodoForm 16 success_url = reverse_lazy('list') 17 18 def form_valid(self, form): 19 todo_object = form.save(commit=False) 20 todo_object.user = self.request.user 21 todo_object.save() 22 return super().form_valid(form) 23

投稿2021/01/08 13:11

reol-777

総合スコア14

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問