我安装并导入了 DateTimePicker 并将其用作 Django DateTime 字段的小部件
单击该字段时,它会以 2020 年 7 月 30 日下午 4:33 格式显示日期和时间。
但是,模型不接受输入,因为它需要采用格式:2020-07-30 16:33。任何想法如何操作表单小部件以显示这种格式?
表格.py:
from django import forms
from .models import BlogPost
from tempus_dominus.widgets import DatePicker, TimePicker, DateTimePicker
class BlogPostModelForm(forms.ModelForm):
publish_date = forms.DateTimeField(
widget=DateTimePicker(
options={
'useCurrent': True,
'collapse': False,
# Calendar and time widget formatting
'time': 'fa fa-clock-o',
'date': 'fa fa-calendar',
'up': 'fa fa-arrow-up',
'down': 'fa fa-arrow-down',
'previous': 'fa fa-chevron-left',
'next': 'fa fa-chevron-right',
'today': 'fa fa-calendar-check-o',
'clear': 'fa fa-delete',
'close': 'fa fa-times'
},
attrs={
'append': 'fa fa-calendar',
'icon_toggle': True,
}
)
)
class Meta:
model = BlogPost
fields = ['title','image', 'slug', 'content', 'publish_date']
def clean_title(self, *args, **kwargs):
instance = self.instance
print('instance is: ',instance)
title = self.cleaned_data.get('title')
qs = BlogPost.objects.filter(title__iexact=title)
if instance is not None:
qs = qs.exclude(pk=instance.pk) # id=instance.id
if qs.exists():
raise forms.ValidationError("This title has already been used. Please try again.")
return title
表格.html:
<!doctype html>
{% extends "blog/base.html" %}
{% load static %}
{% load crispy_forms_tags %}
{% block head_title %}
{{title}}
{% endblock %}
{% block content %}
{% if title %}
<h1>{{ title }}</h1>
{% endif %}
<form method='POST' enctype="multipart/form-data" action='.'> {% csrf_token %}
{{ form|crispy }}
{{ form.media }}
<button type='submit'>Send</button>
</form>
{% endblock %}