I want to add or remove new WTForm input fields with button, using Jquery, just like here http://www.sanwebe.com/2013/03/addremove-input-fields-dynamically-with-jquery/comment-page-1 but using my form-fields.
my form:
class EditBook(Form):
title = TextField('title', validators = [Required()])
authors = FieldList(TextField())
problem is that I can't just append for example
$(InputsWrapper).append("{{form.authors(size=20)}}");
it just prints this text.
This answer is based on nsfyn55's explanations (first paragraph).
I had a similar problem. The solution was to use: https://github.com/Rhyzz/repeatable-fields
So, all you have to do is to look at the html snippet that is rendered by WTForms and use it as a 'template' in repeatable-fields plugin (see its docs for details)
Your example conflates text generated server side with text you are appending in the browser using javascript. You will not be able to use the
{{ }}
syntax which is used by the server side templating engine. During rendering these are expanded and replaced with the HTML that is transmitted across the wire to the client. You will instead need to build the actual DOM elements that these built-in template functions would otherwise generate.The DOM element you actually want to create looks like this:
This can then be encoded in a
multipart/form-data
stream that WTForms can work with. So your actually jQuery stuff needs to create a field looks something like thisWhere the
index
is the next positional index(this could be stored in adata
attribute in a wrappingul
) andvalue
is the value you want to assign to this box if any.Additionally to get a feel for what
FieldList
renders you can run the code below from the command line. It will print the actual text that WTForms generates during the rendering process.