1

Django アプリケーションには次のフォームがあります。

class SurveyAreaForm(ModelForm):
    class Media(object):
        js = formset_media_js

    class Meta:
        model = SurveyArea
        exclude = ['survey', ]
        widgets = {
            'action_by': CustomDateInput(),
        }


AreaFormSet = inlineformset_factory(Survey, SurveyArea, form=SurveyAreaForm)

class SurveyForm(ModelForm):
    class Meta:
        model = Survey
        exclude = ['tech', 'operator', ]
        widgets = {
            'date': CustomDateInput(),
            'client': FilteredJQMRadioSelectWithAdd(),
            'assessorSignature': SignatureInput(attrs={'id': 'assessorSignature'}),
        }

    def __init__(self, *args, **kwargs):
        super(SurveyForm, self).__init__(*args, **kwargs)
        self.fields['client'].empty_label = None

私はhttps://pypi.python.org/pypi/django-formset-js/0.3.0を使用して、追加のフォームを追加するための JavaScript を提供しています。

各調査オブジェクトには 1 つ以上の調査エリアを関連付けることができ、同じフォームを使用してそれらを編集可能にしたいと考えています。ただし、初期データのレンダリングで問題が発生しています。これが私の見解です:

class SurveyUpdateView(SurveyValidateMixin, UpdateViewWithTech):
    model = Survey
    form_class = SurveyForm
    success_url="/forms/survey/updated/"
    template_name="my_django_app/survey_update.html"

    def get(self, request, *args, **kwargs):
        """
        Handles GET requests and instantiates blank version of the form
        and its inline formsets.
        """
        self.object = self.get_object()
        form_class = self.get_form_class()
        form = self.get_form(form_class)

        # Get areas
        areas = SurveyArea.objects.filter(survey=self.object).order_by('name').values()

        # Render form
        area_form = AreaFormSet(initial=areas)
        return self.render_to_response(
            self.get_context_data(form=form,
                                area_form = area_form))

    def post(self, request, *args, **kwargs):
        """
        Handles POST requests, instantiating a form instance and its inline
        formsets with the passed POST variables and them checking them for
        validity.
        """
        self.object = self.get_object()
        form_class = self.get_form_class()
        form = self.get_form(form_class)
        area_form = AreaFormSet(self.request.POST)
        if (form.is_valid() and area_form.is_valid()):
            return self.form_valid(form, area_form)
        else:
            return self.form_invalid(form, area_form)

また、SurveyCreateView正常に動作する もあり、検証は を使用してこれらのビュー間で共有されますSurveyValidateMixinSurveyUpdateViewも から継承します。UpdateViewWithTechこれは、基本的にユーザーごとにクエリセットを制限し、ユーザーを表すフィールドを自動的に設定するだけです。

私が抱えている問題は、初期データのレンダリングにあります。のget()方法でSurveyUpdateView、現在その調査に関連付けられているすべてのエリアを取得しています。PDB を使用して、この調査に関連するエリア (変数エリア) を取得した時点で、データは正しいようです。8 アイテムを使用すると、次のようになります。

[{'description': u'A', 'photo': u'', 'action_required': u'A', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 21L, 'action_taken': True, 'name': u'A'}, {'description': u'A', 'photo': u'', 'action_required': u'A', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 19L, 'action_taken': True, 'name': u'A'}, {'description': u'A', 'photo': u'', 'action_required': u'A', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 29L, 'action_taken': True, 'name': u'A'}, {'description': u'A', 'photo': u'', 'action_required': u'A', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 30L, 'action_taken': True, 'name': u'A'}, {'description': u'B', 'photo': u'', 'action_required': u'B', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 22L, 'action_taken': True, 'name': u'B'}, {'description': u'B', 'photo': u'', 'action_required': u'B', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 20L, 'action_taken': True, 'name': u'B'}, {'description': u'B', 'photo': u'', 'action_required': u'B', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 31L, 'action_taken': True, 'name': u'B'}, {'description': u'C', 'photo': u'', 'action_required': u'C', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 23L, 'action_taken': True, 'name': u'C'}, {'description': u'X', 'photo': u'', 'action_required': u'X', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 24L, 'action_taken': True, 'name': u'X'}, {'description': u'Y', 'photo': u'', 'action_required': u'Y', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 25L, 'action_taken': True, 'name': u'Y'}, {'description': u'Z', 'photo': u'', 'action_required': u'Z', 'action_by': datetime.date(2013, 11, 14), 'survey_id': 12L, u'id': 26L, 'action_taken': True, 'name': u'Z'}]

ただし、initialインスタンス化時にそのデータを の値として渡すとAreaFormSet、データが正しくレンダリングされません。の定義でAreaFormSetの値を設定するとextra、その数の領域がレンダリングされます (未定義の場合、3 と表示されます。これが のデフォルト値であると私は信じていますextra)。私が見たい動作は、既存の各領域が独自の形式でレンダリングされることです。

再びPDBを使用して、で設定した後にarea_formの値をダンプするとarea_form.as_table()、で設定されたフォームの数しか得られextraないため、問題は初期データの通過にあるようです。

initialの値を正しく通過していますか? の値は辞書のリストである必要があることを理解しましたinitial。私には正しいように見えますが、レンダリングする領域の正しい数が得られません。

4

1 に答える 1

1

やってみました

area_form = AreaFormSet(instance=self.object)

それ以外の

area_form = AreaFormSet(initial=areas)

?

于 2014-05-02T16:21:24.977 に答える