UNPKG

lighthouse

Version:

Automated auditing, performance metrics, and best practices for the web.

47 lines (40 loc) 2.21 kB
/** * @license * Copyright 2023 Google LLC * SPDX-License-Identifier: Apache-2.0 */ /** * @fileoverview Ensures <img> elements have alternative text that is not repeated text. * See base class in axe-audit.js for audit() implementation. */ import AxeAudit from './axe-audit.js'; import * as i18n from '../../lib/i18n/i18n.js'; const UIStrings = { /** Title of an accessibility audit that evaluates if all image elements have the alt HTML attribute that is not redundant. This title is descriptive of the successful state and is shown to users when no user action is required. */ title: 'Image elements do not have `[alt]` attributes that are redundant text.', /** Title of an accessibility audit that evaluates if all image elements have the alt HTML attribute that is not redundant. This title is descriptive of the failing state and is shown to users when there is a failure that needs to be addressed. */ failureTitle: 'Image elements have `[alt]` attributes that are redundant text.', /** Description of a Lighthouse audit that tells the user *why* they should try to pass. This is displayed after a user expands the section to see more. No character length limits. The last sentence starting with 'Learn' becomes link text to additional documentation. */ description: 'Informative elements should aim for short, descriptive alternative text. ' + 'Alternative text that is exactly the same as the text adjacent to the link or image is ' + 'potentially confusing for screen reader users, because the text will be read twice. ' + '[Learn more about the `alt` attribute](https://dequeuniversity.com/rules/axe/4.11/image-redundant-alt).', }; const str_ = i18n.createIcuMessageFn(import.meta.url, UIStrings); class ImageRedundantAlt extends AxeAudit { /** * @return {LH.Audit.Meta} */ static get meta() { return { id: 'image-redundant-alt', title: str_(UIStrings.title), failureTitle: str_(UIStrings.failureTitle), description: str_(UIStrings.description), scoreDisplayMode: AxeAudit.SCORING_MODES.INFORMATIVE, requiredArtifacts: ['Accessibility'], }; } } export default ImageRedundantAlt; export {UIStrings};