仿阿里巴巴规格选择器,如果你有更好方案,请联系我,45329453@qq.com
如果这个demo
对你有帮助,请点一个★是对我最大的鼓励,感激不尽!
初始化确定按钮颜色置灰,不可点击。
当
spu
颜色数量大于1个时,显示颜色导航,底部列表可以滚动,反之隐藏,布局自适应。如果有颜色导航,输入或点击
+
-
按钮,颜色导航对应的颜色数字同步变化,如果数量大于99显示99+;如果数量小于1不显示。点击
>
<
底部列表和颜色导航同步滚动。输入或点击
+
-
按钮,当按+
到最大库存+
置灰;当按-
到0-
置灰。点击输入框。键盘弹出,规格选择器 上移;点击完成,键盘收回,规格选择器 回到原位。
点击颜色导航条的颜色标签,高亮被点击颜色标签并滚动到屏幕中心,底部列表滑动到对应位置,同时切换
sku
图片。当输入或者点击数量大于1,确定按钮可点击,颜色高亮。
当库存不足的时候,输入框下显示
库存不足
标签。输入框不可输入
0
,.
等特殊符号。列表行自适应高度,布局中心对齐。
点击背景遮罩或者
x
,收回弹窗。动态输入监听,同步显示,根据输入判定确定按钮状态。
数据模型重新组装。
适配
IPhoneX
及以上系列。增加加入到购物车抛物线动画,购物车同步用户选择
sku
数量。
demo
数据是从接口获取,需要连接wifi
或蜂窝网络。
数据结构 (点击箭头展开/收起)
GHSpecificationSelectionTitleModel
颜色导航器模型
GHSpecificationSelectionModel
sku
模型
GHSpecificationSelectionImageModel
图片模型
更新依赖库
cd 项目路径
pod install
如果更新 Pod
遇到问题,可以参考这篇文章
1.初始化对象
GHAlibabaSpecificationSelection
继承 GHPopView
,GHPopView
已经封装好弹出/收回动画,外部无需重复处理。
- (void)show;
- (void)dismiss
GHPopView
暴露一个contentView
容器视图,子控件可以直接添加到这个视图。
@property (nonatomic, strong) UIView *contentView;
其中contentViewHeight
是contentView
容器视图的高度,初始化的时候必传
#import GHAlibabaSpecificationSelection.h
2.传入数据
/**
* 数据源
* @param skuList 装skuModel数组
* @param colors 颜色数组 非必传,如果为空,不显示颜色导航
* @param sectePrice 价格区间字典
*/
3.取出用户选择
4.重置数据
在这个方法内部清除所有
count
。底部
scrollview
滚动到初始化状态。底部确定按钮初始化状态。
scrollTitles
初始化。
- (void) resetData;