Documentation Docs
Documentation Docs

settings

Global settings that apply to all surveys on the page. To specify one of the settings, use the code below:

import { settings } from "survey-core";

settings.settingName = "value";
animationEnabled property

Specifies whether to animate survey elements.

Default value: true

Type:
boolean writable
Implemented in:
settings
autoAdvanceDelay property

Specifies how many milliseconds a survey should wait before it automatically switches to the next page. Applies only when auto-advance is enabled.

Default value: 300

Type:
number writable
Implemented in:
settings
choicesSeparator property

One or several characters used to separate choice options in a list.

Default value: ", "

Type:
string writable
Implemented in:
settings
See also:
settings.itemValueSeparator
commentSuffix property

A suffix added to the name of the property that stores comments.

Default value: "-Comment"

You can specify this setting for an individual survey: commentSuffix.

Type:
string writable
Implemented in:
settings
comparator property

An object that configures string comparison.

Nested properties:

  • trimStrings: boolean
    Specifies whether to remove whitespace from both ends of a string before the comparison. Default value: true.

  • caseSensitive: boolean
    Specifies whether to differentiate between capital and lower-case letters. Default value: false.

Type:
{ trimStrings: boolean; caseSensitive: boolean; normalizeTextCallback: (str: string, reason: string) => string; } writable
Implemented in:
settings

A function that activates a proprietary SurveyJS confirm dialog.

Use the following code to execute this function:

import { settings } from "survey-core";

settings.confirmActionAsync("Are you sure?", (confirmed) => {
  if (confirmed) {
    // ...
    // Proceed with the action
    // ...
  } else {
    // ...
    // Cancel the action
    // ...
  }
});

You can redefine the confirmActionAsync function if you want to display a custom dialog window. Your function should return true to be enabled; otherwise, a survey executes the confirmActionFunc function. Pass the dialog result as the callback parameter: true if a user confirms an action, false otherwise.

Type:
(message: string, callback: (res: boolean) => void, options?: IConfirmDialogOptions) => boolean writable
Parameters:
message, type: string ,

A message to be displayed in the confirm dialog window.

callback, type: (res: boolean) => void ,

A callback function that should be called with true if a user confirms an action or false otherwise.

options, type: IConfirmDialogOptions
Implemented in:
settings

A function that activates a browser confirm dialog.

Use the following code to execute this function:

import { settings } from "survey-core";

// `result` contains `true` if the action was confirmed or `false` otherwise
const result = settings.confirmActionFunc("Are you sure?");

You can redefine the confirmActionFunc function if you want to display a custom dialog window. Your function should return true if a user confirms an action or false otherwise.

Type:
(message: string) => boolean writable
Parameters:
message, type: string ,

A message to be displayed in the confirm dialog window.

Implemented in:
settings
customIcons property

An object that specifies icon replacements. Object keys are built-in icon names. To use a custom icon, assign its name to the key of the icon you want to replace:

import { settings } from "survey-core";

settings.customIcons["icon-redo"] = "custom-redo-icon";

For more information about icons in SurveyJS, refer to the following help topic: UI Icons.

Type:
{} writable
Implemented in:
settings
designMode property

An object that configures survey appearance when the survey is being designed in Survey Creator.

Nested properties:

  • showEmptyDescriptions: boolean
    Specifies whether to display an empty description for pages and panels. Default value: true.

  • showEmptyTitles: boolean
    Specifies whether to display an empty title for pages and panels. Default value: true.

Type:
{ showEmptyDescriptions: boolean; showEmptyTitles: boolean; } writable
Implemented in:
settings

A value to save in survey results when respondents select the "Don't know" choice item.

Default value: "dontknow"

Type:
string writable
Implemented in:
settings
enterKeyAction property

Specifies an action to perform when users press the Enter key within a survey.

Possible values:

  • "moveToNextEditor" - Moves focus to the next editor.
  • "loseFocus" - Removes focus from the current editor.
  • "default" - Behaves as a standard <input> element.
Type:
"moveToNextEditor" | "loseFocus" | "default" writable
Implemented in:
settings

A separator used in a shorthand notation that specifies a value and display text for an ItemValue object: "value|text".

Default value: "|"

Type:
string writable
Implemented in:
settings
See also:
settings.choicesSeparator
lazyRender property

An object that configures lazy rendering.

Nested properties:

  • enabled: boolean
    Specifies whether to add questions to the DOM only when they get into the viewport. Default value: false.

View Demo

Type:
{ enabled: boolean; firstBatchSize: number; } writable
Implemented in:
settings
See also:
SurveyModel.lazyRendering
localization property

An object that contains properties related to localization.

Nested properties:

  • useLocalTimeZone: boolean
    Disable this property if you want internal SurveyJS functions to use methods that work with UTC date and time (setUTCDate() setUTCHours(), etc.) instead of methods that work with local date and time (setYear(), setHours(), etc.). Default value: true.

  • defaultLocaleName: string
    A property key that stores a translation for the default locale. Default value: "default".

  • storeDuplicatedTranslations: boolean
    Specifies whether surveys should store translation strings that equal the translation strings in the default locale. Default value: false.

Type:
{ useLocalTimeZone: boolean; storeDuplicatedTranslations: boolean; defaultLocaleName: string; } writable
Implemented in:
settings
maskSettings property

An object with properties that configure input masks.

Nested properties:

  • patternPlaceholderChar: string
    A symbol used as a placeholder for characters to be entered in pattern masks. Default value: "_".

  • patternEscapeChar: string
    A symbol used to insert literal representations of special characters in pattern masks. Default value: "\\".

  • patternDefinitions: <{ [key: string]: RegExp }>
    An object that maps placeholder symbols to regular expressions in pattern masks. Default value: { "9": /[0-9]/, "a": /[a-zA-Z]/, "#": /[a-zA-Z0-9]/ }.

Type:
{ patternPlaceholderChar: string; patternEscapeChar: string; patternDefinitions: { [key: string]: RegExp; }; } writable
Implemented in:
settings
matrix property

An object with properties that apply to Single-Choice, Multiple-Choice, and Dynamic Matrix questions.

Nested properties:

  • defaultRowName: string
    A property key that stores an object with default cell values. Default value: "default".

  • defaultCellType: string
    The default type of matrix cells. Default value: "dropdown".
    You can specify this setting for individual questions or matrix columns: cellType. Refer to the cellType property description for information on possible values.

  • totalsSuffix: string
    A suffix added to the name of the property that stores total values. The resulting property name consists of the matrix name and the suffix. Default value: "-total".

  • maxRowCount: number
    A maximum number of rows in a Dynamic Matrix. Default value: 1000.
    You can specify this setting for an individual Dynamic Matrix: maxRowCount.

  • maxRowCountInCondition: number
    A maximum number of matrix rows included in the Condition drop-down menu in Survey Creator. This menu is used to configure conditional survey logic. Default value: 1.
    If you set this property to 0, the Condition menu does not include any matrix rows. Users still can specify conditions that use matrix rows but only with Manual Entry.

  • renderRemoveAsIcon: boolean
    Disable this property if you want to render the Remove action in Dynamic Matrix as a button. Otherwise, the action is rendered as an icon. Default value: true.

  • columnWidthsByType: object
    An object that specifies fixed and minimum column width based on the column type.
    Example: settings.matrix.columnWidthsByType = { "tagbox": { minWidth: "240px", width: "300px" } }

  • rateSize: "small" (default) | "normal"
    Specifies the size of rate values. Applies to Rating Scale questions within matrixes.

Type:
{ defaultCellType: string; defaultRowName: string; totalsSuffix: string; maxRowCount: number; maxRowCountInCondition: number; renderRemoveAsIcon: boolean; columnWidthsByType: { [index: string]: { minWidth?: string; width?: string; }; }; rateSize: "small" | "normal"; } writable
Implemented in:
settings

Specifies how many times surveys can re-evaluate expressions when a question value changes. This limit helps avoid recursions in expressions.

Default value: 10

Type:
number writable
Implemented in:
settings
maxDate property

Specifies a maximum date that users can enter into a Text question with inputType set to "date" or "datetime-local". Set this property to a string with the folllowing format: "yyyy-mm-dd".

Type:
string writable
Implemented in:
settings
maxWidth property

A maximum width value for all survey elements.

Default value: "100%"

You can override this setting for individual elements: maxWidth.

Type:
string writable
Implemented in:
settings
minDate property

Specifies a minimum date that users can enter into a Text question with inputType set to "date" or "datetime-local". Set this property to a string with the folllowing format: "yyyy-mm-dd".

Type:
string writable
Implemented in:
settings
minWidth property

A minimum width value for all survey elements.

Default value: "300px"

You can override this setting for individual elements: minWidth.

Type:
string writable
Implemented in:
settings
noneItemValue property

A value to save in survey results when respondents select the "None" choice item.

Default value: "none"

Type:
string writable
Implemented in:
settings
notifications property

An object that configures notifications.

Nested properties:

  • lifetime: number
    Specifies a time period during which a notification is displayed; measured in milliseconds. Default value: 2000.
Type:
{ lifetime: number; } writable
Implemented in:
settings
numbering property

An object with properties that configure question numbering.

Nested properties:

  • includeQuestionsWithHiddenNumber: boolean
    Specifies whether to number questions whose hideNumber property is enabled. Default value: false.

  • includeQuestionsWithHiddenTitle: boolean
    Specifies whether to number questions whose titleLocation property is set to "hidden". Default value: false.

Type:
{ includeQuestionsWithHiddenNumber: boolean; includeQuestionsWithHiddenTitle: boolean; } writable
Implemented in:
settings
panel property

An object with properties that apply to Dynamic Panel questions.

Nested properties:

  • maxPanelCount: number
    A maximum number of panels in Dynamic Panel. Default value: 100.
    You can specify this setting for an individual Dynamic Panel: maxPanelCount.

  • maxPanelCountInCondition: number
    A maximum number of Dynamic Panel panels included in the Condition drop-down menu in Survey Creator. This menu is used to configure conditional survey logic. Default value: 1.
    If you set this property to 0, the Condition menu does not include any panel questions. Users still can specify conditions that use panel questions but only with Manual Entry.

Type:
{ maxPanelCount: number; maxPanelCountInCondition: number; } writable
Implemented in:
settings
parseNumber property

A function that allows you to define custom parsing rules for numbers represented as string values.

The following code shows a template that you can use to implement the parseNumber function:

import { settings } from "survey-core";

settings.parseNumber = (stringValue, numericValue) => {
  if (typeof stringValue !== "string" || !stringValue)
    return numericValue;
  let parsedNumber = numericValue;
  // ...
  // Parsing the number according to custom parsing rules
  // ...
  return parsedNumber;
};
Type:
(stringValue: any, numericValue: number) => number writable
Return Value:

A number that results from parsing the string value.

Implemented in:
settings
See also:
settings.serialization

Specifies which part of a choice item responds to a drag gesture in Ranking questions.

Possible values:

  • "entireItem" (default) - Users can use the entire choice item as a drag handle.
  • "icon" - Users can only use the choice item icon as a drag handle.
Type:
string writable
Implemented in:
settings

A maximum number of rate values in a Rating question.

Default value: 20

Type:
number writable
Implemented in:
settings
readOnly property

An object with properties that configure questions in read-only mode.

Nested properties:

  • commentRenderMode: "textarea" (default) | "div"
    Specifies how to render the input field of Comment questions in read-only mode: as a disabled <textarea> element or as a <div> element with a non-editable question value within it.

  • textRenderMode: "input" (default) | "div"
    Specifies how to render the input field of Text questions in read-only mode: as a disabled <input> element or as a <div> element with a non-editable question value within it.

Type:
{ enableValidation: boolean; commentRenderMode: string; textRenderMode: string; } writable
Implemented in:
settings
refuseItemValue property

A value to save in survey results when respondents select the "Refuse to answer" choice item.

Default value: "refused"

Type:
string writable
Implemented in:
settings
serialization property

An object that contains properties related to JSON serialization.

Nested properties:

  • itemValueSerializeAsObject: boolean
    Enable this property if you want to serialize ItemValue instances (choice options, matrix rows, columns in a Single-Select Matrix) as objects even when they include only the value property. Default value: false.

  • itemValueSerializeDisplayText: boolean
    Enable this property if you want to serialize the text property of ItemValue objects even when it is empty or equal to the value property. Default value: false.

  • localizableStringSerializeAsObject: boolean
    Enable this property if you want to serialize LocalizableString instances as objects even when they include only a translation string for the default locale. For example, "Custom String" will be serialized as { default: "Custom String" }. Default value: false.

  • matrixDropdownColumnSerializeTitle: boolean
    Enable this property if you want to serialize the title property of MatrixDropdownColumn objects even when it is empty or equal to the name property. Default value: false.

Type:
{ itemValueSerializeAsObject: boolean; itemValueSerializeDisplayText: boolean; localizableStringSerializeAsObject: boolean; matrixDropdownColumnSerializeTitle: boolean; } writable
Implemented in:
settings
See also:
settings.parseNumber
showItemsInOrder property

Specifies the direction in which to lay out Checkbox and Radiogroup items. This setting affects the resulting UI when items are arranged in more than one column.

Possible values:

  • "row" (default) - Items fill the current row, then move on to the next row.
  • "column" - Items fill the current column, then move on to the next column.
Type:
string writable
Implemented in:
settings

Allows you to hide the maximum length indicator in text input questions.

If you specify a question's maxLength property or a survey's maxTextLength property, text input questions indicate the number of entered characters and the character limit. Assign false to the settings.showMaxLengthIndicator property if you want to hide this indicator.

Default value: true

Type:
boolean writable
Implemented in:
settings

An object whose properties specify the order of the special choice items ("None", "Other", "Select All", "Refuse to answer", "Don't know") in select-based questions.

Default value: { selectAllItem: [-1], noneItem: [1], otherItem: [2], dontKnowItem: [3], otherItem: [4] }

Use this object to reorder special choices. Each property accepts an array of integer numbers. Negative numbers place a special choice item above regular choice items, positive numbers place it below them. For instance, the code below specifies the following order of choices: None, Select All, regular choices, Other.

import { settings } from "survey-core";

settings.specialChoicesOrder.noneItem = [-2];
settings.specialChoicesOrder.selectAllItem = [-1];
settings.specialChoicesOrder.otherItem = [1];

If you want to duplicate a special choice item above and below other choices, add two numbers to the corresponding array:

settings.specialChoicesOrder.selectAllItem = [-1, 3] // Displays Select All above and below other choices
Type:
{ selectAllItem: number[]; noneItem: number[]; refuseItem: number[]; dontKnowItem: number[]; otherItem: number[]; } writable
Implemented in:
settings
storeUtcDates property

Specifies whether to store date-time values in the following format: "YYYY-MM-DDThh:mm:ss.sssZ". Applies only to form fields with inputType set to "datetime-local".

Default value: false

If you enable this setting, date-time values are converted from local time to UTC when they are saved to the survey's data object, while the question values remain in local time. Therefore, when you specify default values using a question's defaultValue property, you need to use local time, but if you specify them using the data object, use a UTC date-time value in the following format: "YYYY-MM-DDThh:mm:ss.sssZ".

const surveyJson = {
  "elements": [{
    "name": "datetime",
    "type": "text",
    "title": "Select a date and time",
    "inputType": "datetime-local",
    "defaultValue": "2024-07-16T12:15:00" // Local date-time value
  }]
}
import { Model } from "survey-core";
const surveyJson = { ... }
const survey = new Model(surveyJson);

survey.data = {
  datetime: "2024-07-16T12:15:00.000Z" // UTC date-time value
}
Type:
boolean writable
Implemented in:
settings

A list of supported validators by question type.

Type:
{ question: string[]; comment: string[]; text: string[]; checkbox: string[]; imagepicker: string[]; } writable
Implemented in:
settings

Specifies whether to close the drop-down menu of a Multi-Select Dropdown (Tag Box) question after a user selects a value.

This setting applies to all Multi-Select Dropdown questions on a web page. You can use the closeOnSelect property to specify the same setting for an individual Multi-Select Dropdown question.

Type:
boolean writable
Implemented in:
settings
titleTags property

An object that specifies heading levels (<h1>, <h2>, etc.) to use when rendering survey, page, panel, and question titles.

Default value: { survey: "h3", page: "h4", panel: "h4", question: "h5" }

If you want to modify heading levels for individual titles, handle SurveyModel's onGetTitleTagName event.

Type:
{ survey: string; page: string; panel: string; question: string; } writable
Implemented in:
settings
triggers property

An object that contains properties related to triggers.

Nested properties:

  • changeNavigationButtonsOnComplete: boolean
    Specifies whether to re-evaluate an expression associated with the Complete trigger immediately when a question value changes. If the expression evaluates to true, the trigger is executed. Default value: false.
    Keep this property set to false if you want to re-evaluate the Complete trigger's expression only when the respondents navigate to another page.

  • executeCompleteOnValueChanged: boolean
    Specifies whether to replace the Next button with the Complete button when the Complete trigger is going to be executed. Default value: true.

  • executeSkipOnValueChanged: boolean
    Specifies whether to re-evaluate an expression associated with the Skip trigger immediately when a question value changes. If the expression evaluates to true, the trigger is executed. Default value: true.
    Disable this property if you want to re-evaluate the Skip trigger's expression only when respondents navigate to another page.

Type:
{ changeNavigationButtonsOnComplete: boolean; executeCompleteOnValueChanged: boolean; executeSkipOnValueChanged: boolean; } writable
Implemented in:
settings
web property

An object with properties that configure surveys when they work with a web service.

Nested properties:

  • encodeUrlParams: boolean
    Specifies whether to encode URL parameters when you access a web service. Default value: true.

  • cacheLoadedChoices: boolean
    Specifies whether to cache choices loaded from a web service. Default value: true.

  • disableQuestionWhileLoadingChoices: boolean
    Disables a question while its choices are being loaded from a web service. Default value: false.

  • surveyServiceUrl: string
    The URL of the SurveyJS Service API endpoint.

  • onBeforeRequestChoices: (sender: ChoicesRestful, options: { request: XMLHttpRequest })
    An event that is raised before a request for choices is send. Applies to questions with a specified choiceByUrl property. Use the options.request parameter to access and modify the XMLHttpRequest object. For instance, you can add authentication headers to it:

    import { settings } from "survey-core";
    
    settings.web.onBeforeSendRequest = (sender, options) => {
      options.request.setRequestHeader('RequestVerificationToken', requestVerificationToken);
    };
    
Type:
{ onBeforeRequestChoices: (sender: any, options: { request: any; }) => void; encodeUrlParams: boolean; cacheLoadedChoices: boolean; disableQuestionWhileLoadingChoices: boolean; surveyServiceUrl: string; } writable
Implemented in:
settings

Copyright © 2025 Devsoft Baltic OÜ. All rights reserved.

Your cookie settings

We use cookies on our site to make your browsing experience more convenient and personal. In some cases, they are essential to making the site work properly. By clicking "Accept All", you consent to the use of all cookies in accordance with our Terms of Use & Privacy Statement. However, you may visit "Cookie settings" to provide a controlled consent.

Your renewal subscription expires soon.

Since the license is perpetual, you will still have permanent access to the product versions released within the first 12 month of the original purchase date.

If you wish to continue receiving technical support from our Help Desk specialists and maintain access to the latest product updates, make sure to renew your subscription by clicking the "Renew" button below.

Your renewal subscription has expired.

Since the license is perpetual, you will still have permanent access to the product versions released within the first 12 month of the original purchase date.

If you wish to continue receiving technical support from our Help Desk specialists and maintain access to the latest product updates, make sure to renew your subscription by clicking the "Renew" button below.