Saya telah menghabiskan beberapa hari mencoba membuat templat formulir yang dapat digunakan kembali untuk membuat dan memperbarui model dalam formulir Django. Perhatikan bahwa saya menggunakan ModelForm untuk mengubah atau membuat objek. Saya juga menggunakan bootstrap untuk menata formulir saya. Saya menggunakan django_form_tweaks untuk beberapa formulir di masa lalu, tetapi saya membutuhkan beberapa penyesuaian tanpa banyak ketergantungan template. Karena saya sudah memiliki jQuery di Proyek saya, saya memutuskan untuk memanfaatkan propertinya untuk menata formulir saya. Ini kodenya, dan dapat bekerja dengan bentuk apa pun.
#forms.py
from django import forms
from user.models import User, UserProfile
from .models import Task, Transaction
class AddTransactionForm(forms.ModelForm):
class Meta:
model = Transaction
exclude = ['ref_number',]
required_css_class = 'required'
Views.py
@method_decorator(login_required, name='dispatch')
class TransactionView(View):
def get(self, *args, **kwargs):
transactions = Transaction.objects.all()
form = AddTransactionForm
template = 'pages/transaction.html'
context = {
'active': 'transaction',
'transactions': transactions,
'form': form
}
return render(self.request, template, context)
def post(self, *args, **kwargs):
form = AddTransactionForm(self.request.POST or None)
if form.is_valid():
form.save()
messages.success(self.request, 'New Transaction recorded succesfully')
return redirect('dashboard:transaction')
messages.error(self.request, 'Fill the form')
return redirect('dashboard:transaction')
Kode HTML
Catatan: Saya menggunakan modal bootstrap4 untuk menghilangkan kerumitan membuat banyak tampilan. Mungkin lebih baik menggunakan CreateView atau UpdateView generik. Hubungkan Bootstrap dan jqQery
<div class="modal-body">
<form method="post" class="md-form" action="." enctype="multipart/form-data">
{% csrf_token %}
{% for field in form %}
<div class="row">
<div class="col-md-12">
<div class="form-group row">
<label for="" class="col-sm-4 col-form-label {% if field.field.required %}
required font-weight-bolder text-danger{%endif %}">{{field.label}}</label>
<div class="col-sm-8">
{{field}}
</div>
</div>
</div>
</div>
{% endfor %}
<input type="submit" value="Add Transaction" class="btn btn-primary">
</form>
</div>
Kode Javascript ingat untuk memuat ini dalam $(document).ready(function() { /* ... */});
fungsi.
var $list = $("#django_form :input[type='text']");
$list.each(function () {
$(this).addClass('form-control')
});
var $select = $("#django_form select");
$select.each(function () {
$(this).addClass('custom-select w-90')
});
var $list = $("#django_form :input[type='number']");
$list.each(function () {
$(this).addClass('form-control')
});
var $list = $("form :input[type='text']");
$list.each(function () {
$(this).addClass('form-control')
});
var $select = $("form select");
$select.each(function () {
$(this).addClass('custom-select w-90')
});
var $list = $("form :input[type='number']");
$list.each(function () {
$(this).addClass('form-control')
});