I am trying to get access to my props when using a class component decorator, but I keep getting back 'undefined'. The documentation on Vue Router doesn't document any support for using TS. Below is my current setup and link to a Codesanbox.
Codesabox:
https://codesandbox.io/s/vuetify-ts-router-forked-tsgsu
Router.ts:
import Vue from "vue";
import Router from "vue-router";
import CarsView from "./components/Cars.vue";
import OnboardCarset from "./components/Carsform.vue";
Vue.use(Router);
export default new Router({
mode: "history",
routes: [
{ path: "/", redirect: "/cars", component: CarsView },
{ path: "/cars", component: CarsView },
{
path: "/cars/:id",
name: "car-edit",
props: true,
component: OnboardCarset
}
]
});
Main.js:
import Vue from "vue";
import App from "./App";
import vuetify from "./vuetify";
import router from "./router";
Vue.config.productionTip = false;
/* eslint-disable no-new */
new Vue({
router,
vuetify,
el: "#app",
components: { App },
template: "<App/>"
});
App.vue
<template>
<v-app> <router-view></router-view></v-app>
</template>
<script>
export default {
name: "App",
};
</script>
Cars.vue:
<template>
<div>
<router-link :to="{ name: 'car-edit', params: { id: tab } }">
Cars
</router-link>
<router-view name="car-edit" :propsMessage="myArray" />
</div>
</template>
<script lang="ts">
import { Component, Vue } from "vue-property-decorator";
@Component
export default class Cars extends Vue {
public tab: number = 2;
public myArray: Array<string> = [];
constructor() {
super();
this.myArray = ["One", "Two", "Three"];
}
}
</script>
Carsform.vue
<template>
<div>Cars Form</div>
</template>
<script lang="ts">
import { Component, Vue, Prop } from "vue-property-decorator";
@Component
export default class Carsform extends Vue {
@Prop({ type: Array })
propsMessage!: string[];
constructor() {
super();
console.log(this.propsMessage);
}
}
</script>
The prop name should be the same as params
field :
<template>
<div>Cars Form</div>
</template>
<script lang="ts">
import { Component, Vue, Prop } from "vue-property-decorator";
@Component
export default class Carsform extends Vue {
@Prop({ type: Number })
id!: number;
constructor() {
super();
console.log(this.id);
}
}
</script>