# svelte/valid-compile
disallow warnings when compiling.
- ⚙️ This rule is included in
"plugin:svelte/recommended"
.
# 📖 Rule Details
This rule uses Svelte compiler to check the source code.
<script>
/* eslint svelte/valid-compile: "error" */
let src = 'tutorial/image.gif';
</script>
<!-- ✓ GOOD -->
<img {src} alt="Rick Astley dances." />
<!-- ✗ BAD -->
`<img>` element should have an alt attribute
https://svelte.dev/e/a11y_missing_attribute(a11y_missing_attribute) (svelte/valid-compile)<img {src} />
Note that we exclude reports for some checks, such as missing-declaration
, and dynamic-slot-name
, which you can check with different ESLint rules.
# Using svelte.config.js
If you want to suppress messages using warningFilter
or onwarn
like vite-plugin-svelte
, Use eslint.config.js
and specify the information in svelte.config.js
in your parser configuration.
import svelteConfig from './svelte.config.js';
export default [
// ...
{
files: ['**/*.svelte', '*.svelte'],
languageOptions: {
parserOptions: {
svelteConfig: svelteConfig
}
}
}
];
See also User Guide > Specify svelte.config.js
# warningFilter
This rule can use warningFilter
.
Example:
// svelte.config.js
export default {
warningFilter: (warning) => {
if (warning.code === 'a11y-distracting-elements') return false;
if (warning.code === 'a11y_distracting_elements') return false; // for Svelte v5
return true;
}
};
# onwarn
This rule can use onwarn
like vite-plugin-svelte
.
Example:
// svelte.config.js
export default {
onwarn: (warning, handler) => {
if (warning.code === 'a11y-distracting-elements') return;
if (warning.code === 'a11y_distracting_elements') return; // for Svelte v5
handler(warning);
}
};
# 🔧 Options
{
"svelte/valid-compile": [
"error",
{
"ignoreWarnings": false
}
]
}
ignoreWarnings
… If set totrue
, ignores any warnings other than fatal errors reported by the svelte compiler.
<script>
/* eslint svelte/valid-compile: ["error", { ignoreWarnings: true }] */
let src = 'tutorial/image.gif';
</script>
<!-- Ignore -->
<img {src} />
# 🚀 Version
This rule was introduced in eslint-plugin-svelte v0.7.0