0

我安装并导入了 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 %}


4

1 回答 1

1

尝试在选项中添加:“格式”:“YYYY-MM-DD HH:mm”。

于 2020-09-03T19:43:37.307 回答