Vue TypeScript递归组件

时间:2020-07-08 12:22:34

标签: typescript vue.js recursion

我有一个简单的具有递归的打字稿组件:

<template>
  <div :style="{ paddingLeft: depth * 20 + 'px' }">
    <h1>Level {{ depth }}</h1>
    <div v-if="depth < 2">
      <Recursive v-for="i in 3" :key="i" :depth="depth + 1"/>
    </div>
  </div>
</template>

<script lang="ts">
import * as Vue from "vue";
import { Component, Prop } from "vue-property-decorator";

@Component({
  components: { Recursive }
})
class Recursive extends Vue {
  @Prop({ required: true })
  depth!: number;
}

export default Recursive;
</script>

演示: https://codesandbox.io/s/vue-typescript-recursive-12u3q?file=/src/components/Recursive.vue

在开发模式下工作正常。

但是一旦构建完成,递归导入将被编译为以下类型的字符串: <!--function(e,n,r,o){return ln(t,e,n,r,o,!0)}-->而不是html。

我应该怎么做才能使递归正常工作?

1 个答案:

答案 0 :(得分:1)

我忘记在@Component装饰器中设置组件的名称:

@Component({
  name: 'Recursive',
  components: { Recursive }
})

此代码将同时在开发和编译模式下工作。