【超簡単】Django DeleteViewの書き方・基本を解説

※本サイトにはプロモーション・広告が含まれています。

(最終更新月:2021年12月)

「クラスベースビューを使って削除ページを作りたい!」

「DeleteViewってどうやって使うの?」

というDjango初学者の方へ向けた記事となります

当記事では、

  • DeleteViewを継承し、削除ページを作る方法

について解説していきます。

✔YouTube解説動画

当記事の内容は動画を見ながら進めると、約15分程度で完了します。

動画ならではの情報も解説しているので、記事と一緒にご覧ください。

動画の概要欄には、単元ごとのコードを紹介しているgithubページも載せています。

筆者プロフィール

筆者プロフィールアイコン

【現職】プロダクトマネージャー

【副業】ブログ(月間20万PV)/YouTube/Web・アプリ制作

「プログラミング × ライティング × 営業」の経験を活かし、30後半からのIT系職へシフト。現在はプロダクトマネージャーとして、さまざまな関係者の間に入り奮闘してます。当サイトでは、実際に手を動かせるWebアプリの開発を通じて、プログラミングはもちろん、IT職に必要な情報を提供していきます。

【当ブログで紹介しているサイト】

当サイトチュートリアルで作成したデモ版日報アプリ

Django × Reactで開発したツール系Webアプリ

✔人に見せても恥ずかしくないコードを書こう

「リーダブルコード」は、わかりやすく良いコードの定義を教えてくれる本です。

  • 見るからにきれいなコードの書き方
  • コードの分割方法
  • 変数や関数の命名規則

エンジニアのスタンダートとすべき基準を一から解説しています。

何回も読むのに値する本なので、ぜひ手にとって読んでみてください。

DeleteViewの書き方

DeleteViewの書き方のポイントは4つです

  1. DeleteViewのインポートと継承クラスの作成
  2. 「template_name」変数でHTMLテンプレートを指定
  3. 「model」変数へモデルクラスの代入
  4. 「success_url」変数で削除後のリダイレクト先を指定

具体的にコードを見てみましょう

コード例

from django.views.generic.edit import DeleteView

class NippoDeleteView(DeleteView):
    template_name = "nippo/nippo-delete.html"
    model = NippoModel
    success_url = reverse_lazy("nippo-list")

「CreateView」や「UpdateView」と似ていて、とてもシンプルにまとまってます

urls.py

URLとビュークラスを紐付けます

urlpatterns = [
...,
...,
path("delete/<int:pk>/", NippoDeleteView.as_view(), name="nippo-delete"),
....
]

ビュークラス.as_view()を忘れずに!

おまけ:ごちゃごちゃしたインポートをまとめよう

インポートしてるビュークラスをまとめる方法をお伝えします。

なぜなら、urls.pyのビューが以下のとおり、ごちゃごちゃしているからです。

from .views import NippoListView, NippoDetailView, NippoCreateFormView, NippoUpdateFormView, NippoDeleteView

方法はこちら。

from .views import (
                    NippoListView, 
                    NippoDetailView, 
                    NippoCreateFormView,
                    NippoUpdateFormView, 
                    NippoDeleteView
                    )

( )を使って、改行をするのです。

まとめ

モダルで作成したデリートビューはこちら。

いきなり消えてしまっても困るので、BootstrapのModalで、確認コメントと削除ボタンが表示されましたね。

DeleteViewでは、以下の変数を忘れないようにしましょう。

  • template_name
  • model
  • success_url

さて、こちらのDjangoチュートリアルもクラスベースビューは完結です。

次回はユーザーモデルをカスタマイズし、ユーザー名でなく、Eメールアドレスでログインする方法をご紹介します。

タイトルとURLをコピーしました