Advanced Concepts
Accessibility (a11y)
In NativeScript, there are two primary ways to enable first class a11y support in your apps:
- View attribute: accessible="true"
<label text="{N}" accessible="true"></label>- CSS property: a11y-enabled: true
This option allows you to reuse CSS classes to enable a11y features.
.a11y {
  a11y-enabled: true;
}<label text="{N}" class="a11y"></label>Both options provide the flexibility desired when needing to enable a11y properly for your app.
Note
By default, all touchable elements are accessible as expected. (ie, Button, Slider etc.)
Properties 
Various properties exist to further control a11y.
accessibilityLabel 
It's recommended to always use an accessibilityLabel when marking a view as accessible. VoiceOver usage on the device will speak this value so the user knows what element has been selected.
<label
  text="{N}"
  class="a11y"
  accessibilityLabel="The NativeScript logo in textual form"
></label>accessibilityHint 
Provide additional help so users understand what will happen when they perform an action on the accessible element.
<button
  text="Submit"
  class="a11y"
  accessibilityLabel="Button to submit the form"
  accessibilityHint="Submit this form"
></button>iosAccessibilityAdjustsFontSize (iOS only) 
Enable this to allow device font scale affect view font-size. Android has this feature enabled by default.
iosAccessibilityMinFontScale (iOS only) 
Sets the minimum accessibility font scale.
iosAccessibilityMaxFontScale (iOS only) 
Sets the maximum accessibility font scale.
accessibilityIgnoresInvertColors (iOS only) 
When screen colors invert with accessibility, you often don't want views such as photos to be inverted. You can set this to ignore the inversion.
accessibilityLiveRegion (Android only) 
When components dynamically change, we want TalkBack to alert the end user.
- AccessibilityLiveRegion.None: Should not announce changes to this view.
- AccessibilityLiveRegion.Polite: Should announce changes to this view.
- AccessibilityLiveRegion.Assertive: Should interrupt ongoing speech to immediately announce changes to this view.
<Switch checked="true" class="a11y" checkedChange="{{checkedChange}}" />
<TextView
  hint="TextView"
  text="{{switchCheckedText}}"
  accessibilityLiveRegion="{{AccessibilityLiveRegions.Assertive}}"
/>In the above example, method checkedChange changes the switchCheckedText variable. As soon as an end user taps the Switch, TalkBack reads text in the Text view because of its AccessibilityLiveRegions.Assertive property.
accessibilityRole 
Communicates the purpose of an element to the user.
It can be set to one of the following:
- AccessibilityRole.AdjustableElement that can be "adjusted" (e.g. a slider).
- AccessibilityRole.ButtonElement that should be treated as a button.
- AccessibilityRole.CheckboxElement that represents a checkbox which can be checked or unchecked.
- AccessibilityRole.HeaderEement that acts as a header for a section.
- AccessibilityRole.ImageElement that should be treated as an image.
- AccessibilityRole.ImageButtonElement that should be treated as a button and is also an image.
- AccessibilityRole.KeyboardKeyElement that acts as a keyboard key.
- AccessibilityRole.LinkElement that should be treated as a link.
- AccessibilityRole.NoneElement has no role.
- AccessibilityRole.PlaysSoundElement that plays its own sound when activated.
- AccessibilityRole.ProgressBarElement that indicates progress of a task.
- AccessibilityRole.RadioButtonElement is a radio button.
- AccessibilityRole.SearchElement should be treated as a search field.
- AccessibilityRole.SpinButtonElement that behaves like a SpinButton.
- AccessibilityRole.StartsMediaSessionElement starts a media session when it is activated.
- AccessibilityRole.StaticTextElement that should be treated as static text that cannot change.
- AccessibilityRole.SummaryElement that provides summary information when the application starts.
- AccessibilityRole.SwitchElement that behaves like a switch.
accessibilityState 
Current state of an element.
It can be set to one of the following:
- AccessibilityState.SelectedElement is currently selected.
- AccessibilityState.CheckedElement is currently checked.
- AccessibilityState.UncheckedElement is currently unchecked.
- AccessibilityState.DisabledElement is currently disabled.
accessibilityValue 
Current value of an element.
accessibilityElementsHidden 
Whether elements contained within this accessibility element are hidden.
Debugging Accessibility 
The following are the platforms tools for debugging accessibility in your app:
- iOS: Accessibility Inspect
- Android: Test your app's accessibility
- Previous
- Shared Element Transitions
- Next
- Best Practices
