我正在尝试通过使用插槽将幻灯片的HTML传递给一个组件,然后将它们渲染为另一个组件
// carousel.blade.php <my-carousel> <template v-slot:slides> <div>slide 1</div> <div>slide 2</div> </template> </my-carousel>
MyCarousel
然后将每个 <div>
转换为 Swiper 幻灯片。
我可以使用 slots.slides()
循环遍历传递到插槽中的元素。我的问题是,如何在 swiper-slide 内部渲染该元素的内容?
// MyCarousel.vue <script setup> import { useSlots } from "vue"; import { Swiper, SwiperSlide } from 'swiper/vue'; import 'swiper/css'; const slots = useSlots(); console.log(slots.slides()); </script> <template> <div> <swiper> <swiper-slide v-for="(slide, key) in slots.slides()"> <!-- 渲染当前幻灯片/插槽内容 --> </swiper-slide> </swiper> </div> </template> <style scoped> </style>
我知道我可以直接在 Blade 视图中使用 Swiper,但我正在尝试避免这样做,只有在包装在 Vue 组件中时才将幻灯片转换为
。其余时间它将使用普通的 HTML。
P粉9389363042023-09-16 00:11:13
典型的情况,我在发帖后找了很久才找到解决方案。而且它非常简单。
循环中的每个slide
都可以呈现为动态的<component>
<script setup> import { useSlots } from "vue"; import { Swiper, SwiperSlide } from 'swiper/vue'; import 'swiper/css'; const slots = useSlots(); console.log(slots.slides()); </script> <template> <div> <swiper> <swiper-slide v-for="(slide, key) in slots.slides()" v-bind="props"> <component :is="slide" /> </swiper-slide> </swiper> </div> </template> <style scoped> </style>