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

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

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

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

0回答

1778閲覧

DangoのDatetimeFieldにHTML5のDatetime-localを指定すると、初期値Valueで指定した値の表示ができない

ba-cahn

総合スコア10

Django

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2019/02/25 13:46

前提・実現したいこと

Django2.0にてDatetimeFiledで定義したModelに対し、
Formにてwigeht:attrsにてinput_type=datetime-localを指定しております。
画面の動作はdatetime-localの通り、日付のカレンダー、時計の選択が表示されますが、
表示時にシステム日付を表示したいのですが、空の状態(年/月/日 --:--)で表示されてしまいます。
手入力し、データの登録は可能です。

該当のソースコード

python

1#model.py 2 3class TimerTrn(TimeStampedModel): 4 5 class Meta: 6 ordering = ['-target_time'] 7 target_time = models.DateTimeField(verbose_name='設定時刻', default=timezone.now) 8

python

1#form.py 2class TimerForm(forms.ModelForm): 3 ) 4 target_time = forms.DateTimeField( 5 label='設定時間', 6 input_formats=['%Y-%m-%dT%H:%M'], 7 widget=forms.DateTimeInput(attrs={ 8 'type': 'datetime-local', 9 'emptyTips': 'タイマーの設定時間を入力', 10 }) 11 ) 12

python

1#view.py 2 3 4# 一覧画面 5class IndexView(View): 6 def get(self, request, *args, **kwargs): 7 # タスクデータ読み込み 8 timers = TimerTrn.objects.order_by('-target_time') 9 context = { 10 'timers': timers, 11 } 12 return render(request, 'offon/index.html', context) 13 14index = IndexView.as_view() 15 16 17# 追加 18class TimerCreateView(CreateView): 19 model = TimerTrn 20 form_class = TimerForm 21 template_name = "offon/timer_edit.html" 22 success_url = '/' # 成功時にリダイレクトするURL 23 24 25 def form_valid(self, form): 26 # ロギング 27 logger.debug("Timer insert.") 28 trntimer = form.save() 29 trntimer.save() 30 messages.success( 31 self.request, '「{}」を更新しました'.format(form.instance)) 32 # メイン画面にリダイレクト 33 return redirect(reverse('offon:index')) 34 35create = TimerCreateView.as_view() 36 37 38# 更新 39class TimerUpdateView(UpdateView): 40 model = TimerTrn 41 form_class = TimerForm 42 template_name = 'offon/timer_edit.html' 43 pk_url_kwarg = 'pk' 44 context_object_name = 'form' 45 46 def get_context_data(self, **kwargs): 47 context = super().get_context_data(**kwargs) # はじめに継承元のメソッドを呼び出す 48 context["title"] = "タイマー変更" 49 return context 50 51 def form_valid(self, form): 52 trntimer = form.save() 53 trntimer.save() 54 messages.success( 55 self.request, '「{}」を更新しました'.format(form.instance)) 56 # メイン画面にリダイレクト 57 return redirect(reverse('offon:index')) 58update = TimerUpdateView.as_view() 59

python

1#timer_edit.html 2{% load static %} 3{% load humanize %} 4 5{% block page_title %}{{ title }}{% endblock %} 6 7{% block content %} 8<div class="card-header"> 9 <h3 class="card-title">{{ title }}</h3> 10</div> 11<form action="" method="post" class="ui form"> 12 <div class="ui stacked segment"> 13 {% csrf_token %} 14 15 <label>{{ form.target_time.label }} </label><br>{{ form.target_time }} 16 {{ form.errors.target_time }} 17 18 <label>{{ form.switch_dt.label }}</label><br> 19 <div class="btn-group-toggle" data-toggle="buttons"> 20 {% for choice in form.switch_dt %} 21 <label for="{{ choice.id_for_label }}" class="btn btn-outline-secondary">{{ choice.choice_label }}{{ choice.tag }}</label> 22 {% endfor %} 23 {{ form.errors.switch_dt }} 24 </div> 25 </div> 26 <button type="submit" class="btn btn-primary">更新</button> 27</form> 28{% endblock %} 29 30

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問