Logo

dev-resources.site

for different kinds of informations.

Where to put constants in a .vue file

Published at
7/30/2023
Categories
vue
javascript
webdev
Author
The Jared Wilcurt
Categories
3 categories in total
vue
open
javascript
open
webdev
open
Where to put constants in a .vue file

I often end up wishing there was a constants section in Vue, like data or methods. But something that useful will never be added into the framework, so instead I made a plugin to add it myself.

But lets explore the problem the plugin solves first:

import {
  A_CONSTANT_VALUE,
  ANOTHER_VALUE
} from '@/helpers/constants.js';

export default {
  data: function () {
    return {
      A_CONSTANT_VALUE,
      ANOTHER_VALUE
    };
  }
};

This isn't great, because data is for reactive values that can be changed, and constants shouldn't be changed. The same problem happens if you return the constants from a setup function. So instead I could put them in computed, like so:

import {
  A_CONSTANT_VALUE,
  ANOTHER_VALUE
} from '@/helpers/constants.js';

export default {
  computed: {
    A_CONSTANT_VALUE: function () {
      return A_CONSTANT_VALUE;
    },
    ANOTHER_VALUE: function () {
      return ANOTHER_VALUE;
    }
  }
};

However, that ends up with a lot of boilerplate. So to get the best of both worlds, I created a Vue plugin to automate away all of that boilerplate.

Here's what the plugin lets you do

import {
  A_CONSTANT_VALUE,
  ANOTHER_VALUE
} from '@/helpers/constants.js';

export default {
  constants: {
    A_CONSTANT_VALUE,
    ANOTHER_VALUE
  }
};

The plugin then runs the following code in every component during the beforeCreate lifecycle hook.

// Checks if the component is using the Options API and
// has a constants section
const constants = this.$options.constants;
if (constants) {
  // Create a computed property for each constant
  const computeds = {};
  Object.keys(constants).forEach(function (constantKey) {
    computeds[constantKey] = function () {
      // Freeze all non-primitives
      return Object.freeze(constants[constantKey]);
    };
  });
  // Add the computed constants to the computed
  // properties in the current component
  this.$options.computed = {
    ...this.$options.computed,
    ...computeds
  };
}

There is one downside to this approach, some IDEs/Editors will let you ctrl+click to go from the constant in the template to its definition in the script. This breaks that functionality. Though it should be possible to allow for it, I'm just not familiar with how. So if you know how, then create a PR to improve the plugin.

Here is the plugin, so you too can use this solution:

https://github.com/TheJaredWilcurt/vue-options-api-constants-plugin

Tell your friends. Let's get this to be a normal part of Vue.

Featured ones: