轮播图代码位于 packages/semi-ui/carousel/index.tsx
,代码量不多。
data:image/s3,"s3://crabby-images/4c47b/4c47b67282a45fcd0acc2366c9538de8cfcd0a41" alt=""
核心同样是这个 foundation
属性,类型为 CarouselFoundation
。
data:image/s3,"s3://crabby-images/510b3/510b3f9177b8c1acacb1b66ed62efdf895dc9eb9" alt=""
CarouselFoundation
封装了轮播图的操作方法,通过传入的 adapter
,管理轮播图组件的 state
。
data:image/s3,"s3://crabby-images/e9bfd/e9bfdd546c74f8a6dee6c27a7f61ab36f737db7d" alt=""
adapter
目的是操作组件的 state
属性。
data:image/s3,"s3://crabby-images/53a3d/53a3d62987852731f0d9f5606c428afd216d22df" alt=""
组件暴露的方法实际上调用的是 foundation
的方法。
data:image/s3,"s3://crabby-images/e77be/e77be3e69af745627747279fba4c0e3b87d5c4ca" alt=""
renderChildren
方法渲染传给轮播图组件的子元素。
data:image/s3,"s3://crabby-images/5399e/5399e3542dfd43bdce0ae104b977531c83f32909" alt=""
renderIndicator
, renderArrow
分别渲染指示器和切换箭头。
最后 render
方法返回一个 div
容器,包裹整个组件。
data:image/s3,"s3://crabby-images/6bc41/6bc41f2847a171571616215741fbbe89f8345531" alt=""
本文完,下期详细解释这个 foundation
模式。