Формы Django - DateInput не заполняется из экземпляра - PullRequest
1 голос
/ 09 октября 2019

Я пытаюсь настроить форму редактирования для модели Django, которая включает DateField. Я установил это поле как forms.DateInput в forms.py. Это прекрасно работает для создания нового экземпляра модели, но когда я пытаюсь заполнить форму существующим экземпляром, поле DateInput остается пустым, даже если все остальные поля заполнены правильно.

Если я вернусь кввод TextField по умолчанию, тогда данные вызываются корректно. Я также пытался установить формат в виджете DateInput.

models.py

class Rider(models.Model):
    first_name = models.CharField(max_length=40)
    surname = models.CharField(max_length=40)
    MALE = 'M'
    FEMALE = 'F'
    GENDER_CHOICES = [
        (MALE, 'Male'),
        (FEMALE, 'Female'),
    ]
    gender = models.CharField(max_length=1, choices=GENDER_CHOICES)
    dob = models.DateField("Date of Birth", auto_now = False, auto_now_add = False)
    club = models.CharField(max_length=50,blank=True, null=True)
    bc_number = models.IntegerField("British Cycling Membership Number", blank=True, null=True)
    linked_account = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, default=1)

views.py

def rider_edit(request, pk):
    rider = get_object_or_404(Rider, pk=pk)
    if request.method == "POST":
        form = RiderForm(request.POST, prefix='rider', instance=rider)
        if form.is_valid():
            rider = form.save(commit=False)
            rider.linked_account = request.user
            rider.save()

            return redirect('rider_list')
    else:
        form = RiderForm(prefix='rider', instance=rider)
    return render(request, 'riders/rider_new.html', {'riderform': form})

form.py

from django import forms
from .models import Rider, MedicalInfo


class RiderForm(forms.ModelForm):

    class Meta:
        model = Rider
        fields = ('first_name', 'surname', 'gender', 'dob', 'club', 'bc_number')
        widgets= {
            'dob': forms.DateInput(attrs={'type': 'date'}, format='%d/%m/%Y')
        }

rider_new.html

<h2>New Rider</h2>
    <form method="POST" class="post-form">
        {% csrf_token %}
        {{ riderform.as_p }}
        <button type="submit" class="save btn btn-default">Add Rider</button>
    </form>

Поле dob - это единственное поле, которое не заполняется правильно из базы данных, оно должно отображать дату в формате дд / мм / ГГГГ, например "10/09/2010" . На самом деле он показывает значение по умолчанию "дд / мм / ГГГГ".

1 Ответ

0 голосов
/ 09 октября 2019

Я нашел решение проблемы, дата из базы данных возвращалась в формате «% d /% m /% Y», но вход в форму был типа «дата», который ожидает ввода вформат "% Y-% m-% d", изменив:

widgets= {
            'dob': forms.DateInput(format=('%d/%m/%Y'), attrs={'class':'form-control', 'placeholder':'Select Date','type': 'date'})
        }

на:

widgets= {
            'dob': forms.DateInput(format=('%Y-%m-%d'), attrs={'class':'form-control', 'placeholder':'Select Date','type': 'date'})
        }

Поэтому сгенерированная HTML-форма изменилась с:

<input type="date" name="rider-dob" value="10/09/2010" class="form-control" placeholder="Select Date" required="" id="id_rider-dob">

до:

<input type="date" name="rider-dob" value="2010-09-10" class="form-control" placeholder="Select Date" required="" id="id_rider-dob">
...