我有一个简单的具有递归的打字稿组件:
<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。
我应该怎么做才能使递归正常工作?
答案 0 :(得分:1)
我忘记在@Component
装饰器中设置组件的名称:
@Component({
name: 'Recursive',
components: { Recursive }
})
此代码将同时在开发和编译模式下工作。