组件在它的模板内可以递归地调用自己,不过,只有当它有 name 选项时才可以:
name: 'unique-name-of-my-component'
当你利用 Vue.component 全局注册了一个组件, 全局的ID作为组件的 name 选项,被自动设置.
Vue.component
Vue.component('unique-name-of-my-component', { // ...})
如果你不谨慎, 递归组件可能导致死循环:
name: 'stack-overflow',template: '<div><stack-overflow></stack-overflow></div>'
上面组件会导致一个错误 “max stack size exceeded” ,所以要确保递归调用有终止条件 (比如递归调用时使用 v-if 并让他最终返回 false )。