Skip to content

Latest commit

 

History

History
90 lines (72 loc) · 1.8 KB

vue.md

File metadata and controls

90 lines (72 loc) · 1.8 KB

Vue

We encourage you to use defineComponent to make the logic of your component.

Props

The props cannot natively be typed with TypeScript with defineComponent:

export default defineComponent({
  props: {
    stringExample: {
      type: String,
      required: true,
    },
  },
  //…
});

Here the prop stringExample is typed from the JavaScript String object and not from the string type.

Sometimes we want to have more complex types like an array of string or a more complex object.

That's why we've added arrayType and objectType utilities from @/vue/VueProp.

Example for a prop arrayOfStrings using string[] type:

import { arrayType } from '@/vue/VueProp';

export default defineComponent({
  props: {
    arrayOfStrings: {
      type: arrayType<string>(),
      required: true,
    },
  },
  //…
});

Example for a prop customObject using CustomObject type:

import { objectType } from '@/vue/VueProp';

interface CustomObject {
  stringField: string;
  numberField: number;
}

export default defineComponent({
  props: {
    customObject: {
      type: objectType<CustomObject>(),
      required: true,
    },
  },
  //…
});

With the two functions, you're now able to type and get the good types when you inject your props from the setup:

import { arrayType, objectType } from '@/vue/VueProp';

interface CustomObject {
  stringField: string;
  numberField: number;
}

export default defineComponent({
  props: {
    customObject: {
      type: objectType<CustomObject>(),
      required: true,
    },
    arrayOfStrings: {
      type: arrayType<string>(),
      required: true,
    },
  },
  setup(props) {
    props.customObject; // Typed as CustomObject
    props.arrayOfStrings; // Typed as string[]
  },
});