Vue中的children是一個非常重要的概念,也是vue組件間通訊的一種方式。children可以理解為子元素,也就是在父組件中嵌套其他組件或HTML元素。在Vue中,可以通過以下兩種方式來添加組件之間的子元素:
<template> <div> <my-component> <p>I am a child element</p> </my-component> </div> </template>
上面代碼中的p元素就是my-component的子元素。 如果要在組件中添加多個子元素,可以使用Vue中提供的一個特殊的元素——slot。
<template> <div> <my-component> <template v-slot:default> <p>I am a child element</p> <p>I am a second child element</p> </template> </my-component> </div> </template>
上面的代碼中,使用了v-slot指令加上了一個具名插槽,具體含義在下面會講到。在具名插槽中可以添加多個子元素,這些子元素會被嵌套到my-component組件中。但這里需要注意的是,要使用具名插槽,my-component組件中需要使用slot元素,如下所示。
<template> <div> <slot></slot> </div> </template>
這里的slot元素就是在my-component中添加子組件的地方。如果在沒有指定插槽名稱的情況下,在父組件中添加的子元素會插入到默認插槽中。因此,使用slot元素時需要像上面的代碼一樣使用v-slot來命名插槽。具名插槽的優勢在于,可以根據插槽的名稱來封裝不同的子組件,從而使組件的復用性更高。