Documentation Docs
Documentation Docs

Configure Question Titles

You can specify the title property to set a question title. If you leave it unspecified, the question displays its name value as a title. However, question titles can have additional elements that you can configure, such as question numbers and required marks.

Question Numbers

Surveys support the following numbering modes:

  • Sequential numbering
    Survey elements are numbered in order, regardless of whether they are nested in panels or not.

  • Recursive numbering
    Survey elements are numbered in a manner that takes into account their nesting level (for example, 1 → 1.1 → 1.1.1).

  • Sequential numbering with a reset on each page
    Survey elements are numbered in order, but the numbering starts anew on each page.

By default, questions are not numbered. To enable one of the numbering modes, set SurveyModel's showQuestionNumbers property to true (sequential numbering), "recursive", or "onpage".

const surveyJson = {
  // ...
  "showQuestionNumbers": true // or "recursive" | "onpage"
}

Questions within panels can participate in survey-level numbering or have an individual numbering sequence. Use PanelModel's showQuestionNumbers property to specify the desired numbering mode: "default" to continue survey-level numbering, "recursive" to number nested questions recursively, "onpanel" to start numbering within the panel from scratch, or "off" to hide numbers for nested questions. For example, the following code enables sequential numbering across the survey but resets numbering for questions within the panel.

const surveyJson = {
  // ...
  "showQuestionNumbers": true,
  "elements": [{
    "type": "panel",
    // ...
    "elements": [ /* ... */ ],
    "showQuestionNumbers": "onpanel"
  }]
}

When enabled, question numbering starts with 1. If you want to start numbering with a different number or use letters instead, specify the Survey's questionStartIndex property. You can include desired prefixes and postfixes in the property value:

const surveyJson = {
  // ...
  "questionStartIndex": "a.", // a., b., c., ...
  "questionStartIndex": "#3", // #3, #4, #5, ...
  "questionStartIndex": "(B)." // (B)., (C)., (D)., ...
}

Required Mark

Questions that require an answer are marked with an asterisk *. You can use the Survey's requiredMark property to set another symbol or specify an explanatory text string:

const surveyJson = {
  // ...
  "requiredMark": "!"
}

Title Pattern

You can arrange the question title, number, and required mark in different sequences. To do this, specify one of the questionTitlePattern property values as shown in the following code:

const surveyJson = {
  // ...
  "questionTitlePattern": "numTitleRequire", // 1. Question Title *
  "questionTitlePattern": "numRequireTitle", // 1. * Question Title  
  "questionTitlePattern": "numTitle",        // 1. Question Title
}

View Demo

Send feedback to the SurveyJS team

Need help? Visit our support page

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.