AJAX form submission (inline success) AJAX form submission (redirect on success) Accordion Autocomplete Input Widget Autocomplete Input Widget (with Remote Data Source) Checkbox Choice Widget Checkbox Choice Widget (inline) Checkbox Choice Widget (read-only) Checkbox Choice Widget (with required field) Checkbox Widget Checkbox Widget (read-only) Checkbox Widget (with Label) Checked Input Widget Checked Input Widget (read-only) Checked Input Widget (with Input Mask) Checked Password Widget Checked Password Widget (read-only) Checked Password Widget (redisplay on validation failure) Custom classes on outermost html element of Widgets Date Input Widget Date Parts Widget Date Parts Widget (read-only) DateTime Input Widget DateTime Input Widget (read-only) Deferred Schema Bindings Don't Validate Readonly Fields Dynamic fields: add and remove Edit Form Field Defaults File Upload Widget File Upload Widget (read-only) Hidden Widget Hidden Widget (missing, representing an Integer) Inter-Field Validation Internationalization Mapping Widget Money Input Multiple Error Messages For a Single Widget (Mapping) Multiple Error Messages For a Single Widget (Sequence) Multiple Forms on the Same Page Non-Required Fields Non-Required Number Fields Password Widget Password Widget (redisplay on validation failure) Popup and retail rendering Pyramid CSRF Demo (using schema binding) Radio Choice Widget Radio Choice Widget (inline) Radio Choice Widget (read-only) Radio Choice Widget (with int values) Readonly HTML Attribute Readonly Widget Argument Require One Field or Another Rich Text Widget (TinyMCE) Rich Text Widget (delayed) Rich Text Widget (internationalized) Rich Text Widget (read-only) Select Widget Select Widget (read-only) Select Widget (with Integer values) Select Widget (with default) Select Widget (with deferred choices and default) Select Widget (with multiple default integers) Select Widget (with multiple) Select Widget (with optgroup and label attributes) Select Widget (with optgroup) Select Widget (with size) Select Widget (with unicode) Select2 Widget Select2 Widget (with multiple) Select2 Widget (with optgroup) Select2 Widget (with tags and multiple) Select2 Widget (with tags) Selectize Widget Selectize Widget (with multiple) Selectize Widget (with optgroup) Selectize Widget (with tags and multiple) Selectize Widget (with tags) Sequence (of Mappings) with Ordering Enabled Sequence With Prototype that Has No Name Sequence of Autocomplete Widgets Sequence of Constrained Min and Max Lengths Sequence of Date Inputs Sequence of Defaulted Selects Sequence of Defaulted Selects (with Initial Item) Sequence of File Upload Widgets Sequence of File Upload Widgets (with Initial Item) Sequence of I18N Sequence of Mapping Widgets Sequence of Mapping Widgets (with Initial Item) Sequence of Mappings (read-only) Sequence of Masked Text Inputs Sequence of Radio Choice Widgets Sequence of Rich Text Widgets Sequence of Sequence Widgets Text Area CSV Widget Text Area Widget Text Area Widget (read-only) Text Input CSV Widget Text Input Masks Text Input Widget Text Input Widget (read-only) Text Input Widget (with CSS class) Text Input Widget (with arbitrary HTML5 attributes) Time Input Unicode Everywhere Widget Adapter

Demo: Dynamic fields: add and remove

Add ?nofield1 to URL to delete this field

May or may not appear. Hit refresh.

Dynamically created

Captured submission

None
    @view_config(renderer="templates/form.pt", name="dynamic_field")
    @demonstrate("Dynamic fields: add and remove")
    def dynamic_field(self):
        class Schema(colander.Schema):

            field1 = colander.SchemaNode(
                colander.String(),
                title="Field 1",
                description="Add ?nofield1 to URL to delete this field",
            )

            field2 = colander.SchemaNode(
                colander.String(),
                title="Field 2",
                description="May or may not appear. Hit refresh.",
            )

            def after_bind(self, schema, kwargs):

                # after_bind() can be used as subclass method
                # or a parameter passed to schema constructor.
                #
                # When schema is bound you are free to post-process any fields:
                # Hide fields, change widgets or dynamically add more fields.
                # You can read request, request.session and other variables
                # here to fulfill conditions.
                #
                # More abount binding:
                #
                # http://docs.pylonsproject.org/projects/colander/en/latest/binding.html
                #
                # http://docs.pylonsproject.org/projects/colander/en/latest/binding.html#after-bind
                #

                request = kwargs["request"]

                if "nofield1" in request.params:
                    del self["field1"]

                if random.random() < 0.5:
                    del self["field2"]

                # Dynamically add new field
                self["field3"] = colander.SchemaNode(
                    colander.String(),
                    title="Field 3",
                    description="Dynamically created",
                )

        schema = Schema()
        schema = schema.bind(request=self.request)

        form = deform.Form(schema, buttons=("submit",))

        return self.render_form(form)