Arrays
Arrays are defined with a type equal to array, and array items' schemas are specified in the items keyword.
Arrays of a single field
Arrays of a single field type can be specified as follows:
import { RJSFSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  items: {
    type: 'string',
  },
};
render(<Form schema={schema} validator={validator} />, document.getElementById('app'));
Arrays of objects
Arrays of objects can be specified as follows:
import { RJSFSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  items: {
    type: 'object',
    properties: {
      name: {
        type: 'string',
      },
    },
  },
};
render(<Form schema={schema} validator={validator} />, document.getElementById('app'));
uiSchema for array items
To specify a uiSchema that applies to array items, specify the uiSchema value within the items property:
import { RJSFSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  items: {
    type: 'string',
  },
};
const uiSchema = {
  items: {
    'ui:widget': 'textarea',
  },
};
render(<Form schema={schema} uiSchema={uiSchema} validator={validator} />, document.getElementById('app'));
NOTE: The
itemsproperty inuiSchemacan also accept a function for dynamic UI schema generation based on array item data. See Dynamic UI Schema Examples for advanced use cases.
The additionalItems keyword
The additionalItems keyword allows the user to add additional items of a given schema. For example:
import { RJSFSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  items: {
    type: 'string',
  },
  additionalItems: {
    type: 'boolean',
  },
};
render(<Form schema={schema} validator={validator} />, document.getElementById('app'));
Array item uiSchema options
Any of these options can be set globally if they are contained within the ui:globalOptions block.
They can also be overridden on a per-field basis inside a ui:options block as shown below.
orderable option
Array items are orderable by default, and react-jsonschema-form renders move up/down buttons alongside them. The uiSchema orderable options allows you to disable ordering:
import { RJSFSchema, UiSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  items: {
    type: 'string',
  },
};
const uiSchema: UiSchema = {
  'ui:options': {
    orderable: false,
  },
};
render(<Form schema={schema} uiSchema={uiSchema} validator={validator} />, document.getElementById('app'));
addable option
If either items or additionalItems contains a schema object, an add button for new items is shown by default. You can turn this off with the addable option in uiSchema:
import { RJSFSchema, UiSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  items: {
    type: 'string',
  },
};
const uiSchema: UiSchema = {
  'ui:options': {
    addable: false,
  },
};
render(<Form schema={schema} uiSchema={uiSchema} validator={validator} />, document.getElementById('app'));
copyable option
A copy button is NOT shown by default for an item if items contains a schema object, or the item is an additionalItems instance.
You can turn this ON with the copyable option in uiSchema:
import { RJSFSchema, UiSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  items: {
    type: 'string',
  },
};
const uiSchema: UiSchema = {
  'ui:options': {
    copyable: true,
  },
};
render(<Form schema={schema} uiSchema={uiSchema} validator={validator} />, document.getElementById('app'));
removable option
A remove button is shown by default for an item if items contains a schema object, or the item is an additionalItems instance. You can turn this off with the removable option in uiSchema:
import { RJSFSchema, UiSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  items: {
    type: 'string',
  },
};
const uiSchema: UiSchema = {
  'ui:options': {
    removable: false,
  },
};
render(<Form schema={schema} uiSchema={uiSchema} validator={validator} />, document.getElementById('app'));
Multiple-choice list
The default behavior for array fields is a list of text inputs with add/remove buttons. There are two alternative widgets for picking multiple elements from a list of choices. Typically, this applies when a schema has an enum list for the items property of an array field, and the uniqueItems property set to true.
Example:
import { RJSFSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  title: 'A multiple-choice list',
  items: {
    type: 'string',
    enum: ['foo', 'bar', 'fuzz', 'qux'],
  },
  uniqueItems: true,
};
render(<Form schema={schema} validator={validator} />, document.getElementById('app'));
By default, this will render a multiple select box. If you prefer a list of checkboxes, just set the uiSchema ui:widget directive to checkboxes for that field:
import { RJSFSchema, UiSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  title: 'A multiple-choice list',
  items: {
    type: 'string',
    enum: ['foo', 'bar', 'fuzz', 'qux'],
  },
  uniqueItems: true,
};
const uiSchema: UiSchema = {
  'ui:widget': 'checkboxes',
};
render(<Form schema={schema} uiSchema={uiSchema} validator={validator} />, document.getElementById('app'));
Custom widgets
In addition to ArrayFieldTemplate you use your own widget by providing it to the uiSchema with the property of ui:widget.
Example:
import { RJSFSchema, UiSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const CustomSelectComponent = (props) => {
  return (
    <select>
      {props.value.map((item, index) => (
        <option key={index} id='custom-select'>
          {item}
        </option>
      ))}
    </select>
  );
};
const schema: RJSFSchema = {
  type: 'array',
  title: 'A multiple-choice list',
  items: {
    type: 'string',
  },
};
const uiSchema: UiSchema = {
  'ui:widget': 'CustomSelect',
};
const widgets = {
  CustomSelect: CustomSelectComponent,
};
render(
  <Form schema={schema} uiSchema={uiSchema} widgets={widgets} validator={validator} />,
  document.getElementById('app'),
);
Specifying the minimum or maximum number of items
Note that when an array property is marked as required, an empty array is considered valid. If the array needs to be populated, you can specify the minimum number of items using the minItems property.
Example:
import { RJSFSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  minItems: 2,
  title: 'A multiple-choice list',
  items: {
    type: 'string',
    enum: ['foo', 'bar', 'fuzz', 'qux'],
  },
  uniqueItems: true,
};
render(<Form schema={schema} validator={validator} />, document.getElementById('app'));
You can also specify the maximum number of items in an array using the maxItems property.
Inline checkboxes
By default, checkboxes are stacked. If you prefer them inline, set the inline property to true:
import { RJSFSchema, UiSchema } from '@rjsf/utils';
import validator from '@rjsf/validator-ajv8';
const schema: RJSFSchema = {
  type: 'array',
  minItems: 2,
  title: 'A multiple-choice list',
  items: {
    type: 'string',
    enum: ['foo', 'bar', 'fuzz', 'qux'],
  },
  uniqueItems: true,
};
const uiSchema: UiSchema = {
  'ui:widget': 'checkboxes',
  'ui:options': {
    inline: true,
  },
};
render(<Form schema={schema} uiSchema={uiSchema} validator={validator} />, document.getElementById('app'));