Field object
Each field object contains the metadata specified in form builder for the specific form it resides in. It can render its label, input field, instructions and errors out of the box.
Properties
- 
id#
- 
handle#
- 
label#
- 
instructions#
- 
required: true#- A boolean value. trueif the field is required.
 
- A boolean value. 
- 
errors#- An array of error message strings if any are present after submitting the form.
 
- 
pageIndex#- A number representing the page index this field resides on.
 
- 
customAttributes#- An object of customizable attributes to ease the customizability of rendermethods.
- Contains the following properties (each one is nullif not set).- id#- The ID attribute of the HTML input field for renderInput().
- When used on renderLabel(), it will replace the defaultforattribute value.
 
- The ID attribute of the HTML input field for 
- class#- The CLASS attribute of the HTML input field for renderInput().
 
- The CLASS attribute of the HTML input field for 
- labelClass#- The CLASS attribute of the HTML label field for renderLabel().
 
- The CLASS attribute of the HTML label field for 
- errorClass#- The CLASS attribute of the errors HTML list for renderErrors().
 
- The CLASS attribute of the errors HTML list for 
- instructionsClass#- The CLASS attribute of the instructions HTML field for renderInstructions().
 
- The CLASS attribute of the instructions HTML field for 
- instructionsBelowField#- A boolean value.
- Set to trueto render instructions below, not above the input field when using therender()method.
 
- overrideValue#- An override value for the field's defaultValuein case you need a context specific default value.
 
- An override value for the field's 
- inputAttributes#- An object of attributes which will be added to the input field. If the form has inputAttributesspecified, the attributes will be merged together with fieldinputAttributestaking precedence over form'sinputAttributes.
- Ex: inputAttributes: { "readonly": true, "data-field-id": "test" }
 
- An object of attributes which will be added to the input field. If the form has 
- useRequiredAttribute: true#- Adds requiredattribute to input fields that have been set to be required in Composer.
 
- Adds 
 
 
- An object of customizable attributes to ease the customizability of 
- 
value#- The default or posted value of the field.
- Can be a string, number or array (it's an array only for checkbox_group and email fields)
 
- 
valueAsString#- The valuevalue cast as a string.
- Array values get joined via a ,separator.
- Uses the selected option labels for checkbox_groupandradio_group.- Use getValueAsString(false)to use selected option values instead.
 
- Use 
 
- The 
- 
type#- Type of the field:
- text
- textarea
- hidden
- select
- checkbox
- checkbox_group
- radio_group
- email
- dynamic_recipients
- file
- mailing_list
- html
- submit
- number
- rating
 
 
- Type of the field:
Field Specific Properties
The following are field specific properties for the basic field types (see below for additional Pro Field Types):
- text#- placeholder
 
- textarea#- placeholder
 
- select#- options- An array of option objects with labelandvalueproperties.
 
- An array of option objects with 
 
- multiple_select#- options- An array of option objects with labelandvalueproperties.
 
- An array of option objects with 
 
- checkbox#- Has a default value of Yes, which can be overwritten with any value you want. The front end however, will always display the value as 1, but upon submission, the value will be switched to the one you have set.
 
- Has a default value of Yes, which can be overwritten with any value you want. The front end however, will always display the value as 
- checkbox_group#- options- An array of option objects with labelandvalueproperties.
 
- An array of option objects with 
 
- radio_group#- options- An array of option objects with labelandvalueproperties.
 
- An array of option objects with 
 
- submit#- labelNext- A label for the Next button. Submitby default.
 
- A label for the Next button. 
- labelPrev- A label for the Previous button. Previousby default.
 
- A label for the Previous button. 
- disablePrev- A boolean value. If truethe Previous button should not be rendered.
 
- A boolean value. If 
 
- dynamic_recipients#- showAsRadio- A boolean value. If truethe dynamic recipients field should be rendered as radio buttons instead of a select field.
 
- A boolean value. If 
- notificationId- The database ID of the assigned Email Notification Template.
 
- NOTE: When parsing this field semi-manually, be sure to use loop.index0to generate numeric values of options instead offieldName.value.
 
- email#- placeholder
- notificationId- The database ID of the assigned Email Notification Template.
 
 
- file#- fileKinds- An array of allowed file kinds, e.g. image,document,audio, etc.
 
- An array of allowed file kinds, e.g. 
- maxFileSizeKB- The numeric representation of the upload limit in kilobytes.
 
- fileCount- The maximum number of allowed files to be uploaded.
- Specify a number larger than 1to allow multiple files to be uploaded at the same time.
 
 
Pro Field Specific Properties
The following are field specific properties for Freeform Pro additional field types:
- confirmation- placeholder
 
- datetime#- initialValue
- dateTimeType(e.g.- both)
- generatePlaceholder(e.g.- true)
- dateOrder(e.g.- ymd)
- date4DigitYear(e.g.- true)
- dateLeadingZero(e.g.- true)
- dateSeparator(e.g.- /)
- clock24h(e.g.- false)
- lowercaseAMPM(e.g.- true)
- clockSeparator(e.g.- :)
- clockAMPMSeparate(e.g.- true)
- useDatepicker(e.g.- true)
 
- number#- placeholder
- minLength
- maxLength
- minValue
- maxValue
- decimalCount
- decimalSeparator(e.g.- .)
- thousandsSeparator(e.g.- ,)
- allowNegative(e.g.- false)
 
- phone#- placeholder
- pattern
- countryCode(e.g.- US)
 
- rating#- colorIdle(e.g.- #ddd)
- colorHover(e.g.- gold)
- colorSelected(e.g.- #f70)
- maxValue(e.g.- 5)- To manually render a Rating field to use your own styles, your code might look something like this:
 
 
{% for i in 1..field.maxValue %}
	<label for="rating-{{ i }}">whatever {{ i }}</label>
	<input type="radio" id="rating-{{ i }}" value="{{ i }}" name="{{ field.handle }}">
{% endfor %}
Methods
- render()#- Use this method to render a predefined, minimal markup html block containing the field's label, input field, instructions and list of errors.
- Can receive an object of customAttributesas the first and only argument (optional).
- When using with HTML blocks or Submit buttons, use the hash value provided in property editor in Composer as the handle. Example code would look like:
- {{ form.get('Ajx7jNxXL').render }}
 
 
- renderLabel()#- Use this method to only render the label html field with the field's label inside.
- The label class can be overwritten via form's custom attributes or the field's custom attributes.
 
- renderInput()#- Use this method to only render the field's html input field.
- The class can be overwritten via form's custom attributes or the field's custom attributes.
- Single Checkbox fieldtype has an additional method: renderSingleInput()to render the checkbox input without an additional hidden input.
 
- renderInstructions()#- Use this method to only render the field's html instructions field. (Renders only if there are instructions present).
- The instructions field class can be overwritten via form's custom attributes or the field's custom attributes.
 
- renderErrors()#- Use this method to only render the error message block. (Renders only if there are errors present).
- The error list class can be overwritten via form's custom attributes or the field's custom attributes.
 
- isValid()# * Returns a boolean value of true if the form has been posted and this field doesn't contain any errors.
Usage in Templates
Simple Render
Render the whole field (label, input field, instructions and errors) with a single line:
{{ field.render() }}
Render Each Part Separately
Render each part of the field separately:
{{ field.renderLabel() }}
{{ field.renderInstructions() }}
{{ field.renderInput() }}
{{ field.renderErrors() }}
Customize Output
Fully customize the output of your field:
<label data-label class="label">
	{{ field.label }}
	{% if field.instructions %}
		<span class="instructions">{{ field.instructions }}</span>
	{% endif %}
</label>
<input type="text" name="{{ field.handle }}" value="{{ field.valueAsString }}" data-some-value="my_custom_value_here" />
{% if field.errors %}
	{% for errorString in field.errors %}
		<div class="error">{{ errorString }}</div>
	{% endfor %}
{% endif %}
Override Classes & Values
Render the whole field but override some of the HTML element classes:
{{ field.render({
	class: "freeform-input",
	labelClass: "freeform-label" ~ (field.required ? " freeform-required" : ""),
	errorClass: "freeform-errors",
	instructionsClass: "freeform-instructions",
	instructionsBelowField: true,
	overrideValue: "This is now the new default value",
	inputAttributes: {
		"data-field-id": field.id,
	}
}) }}