Under the hood the constants values are frozen (Object.freeze()
) and returned as cached computed properties, accessible in the template.
npm install --save vue-options-api-constants-plugin
- Import the plugin into your
main.js
and thenapp.use
it, like so:import { createApp } from 'vue'; import constantsPlugin from 'vue-options-api-constants-plugin'; const app = createApp({}); app.use(constantsPlugin); app.mount('#app');
- In any of your Options API components, you can now add a top level
constants
object, like so:<template> <div> {{ BRAND_NAME }} </div> </template> <script> import { BRAND_NAME } from './constants.js'; export default { name: 'AnExample', constants: { BRAND_NAME } }; </script>
<!DOCTYPE html>
<html>
<head>
<title>Example</title>
<script src="https://unpkg.com/vue@3.3.4/dist/vue.global.prod.js"></script>
<script src="https://unpkg.com/vue-options-api-constants-plugin@1.0.0/cdn.js"></script>
</head>
<body>
<div id="app">
{{ AN_EXAMPLE }}
</div>
<script>
const AN_EXAMPLE = 'An example';
const app = Vue.createApp({
constants: {
AN_EXAMPLE
}
});
app.use(window.constantsPlugin);
app.mount('#app');
</script>
</body>
</html>
- The constants are frozen as computed properties under the hood, so you cannot mutate them, and if you attempt, you'll get a warning in the console.
- Gives you separation of concerns and code organization by having a place for all constants to live in each component.
-
data
andsetup
sections would create reactive and mutatable variables, which you don't want for your constants. -
computed
section works, but adds a lot of boilerplate that this plugin is abstracting away for you. -
methods
section would have the same boilerplate as the computed, and additional boilerplate in the template ({{ AN_EXAMPLE() }}
) and in the scripts (this.AN_EXAMPLE()
)
- Ctrl+Click from the template to the defintion doesn't work with Intellisense/VSCode. However, this may be fixable with some editor hints, as other tools, like Vuelidate and Pinia don't have this issue. If you know how to fix this, create a PR.