Skip to content

LQi2009/LQCartViewController

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

LDCartViewController

重新整理了之前的购物车逻辑,删除了部分代码,修改了部分方法,逻辑结构更清晰,复用更容易 #####此demo的swift版本:CartDemo_Swift

本demo完整展示了购物车的处理逻辑, 及实现思路, 具体的业务处理, 还需要根据自己的需求来定制

购物车功能

  • 商品展示
  • 商品选择
  • 价格计算
  • 商品删除

说明

本次更新,重新整理了代码,整体结构更清晰,方便在此基础上进行个人需求的定制

  • 整体布局脱离了对Masnary的依赖 如果需要使用Masnary,可重新设置控件坐标
  • 重写了自定义cell的对外方法 减少了不必要的属性暴漏在.h文件,尽量使用方法来调用相关设置,使用更方便,逻辑更清晰
@interface LZCartTableViewCell : UITableViewCell
//商品数量
@property (assign,nonatomic)NSInteger lzNumber;
@property (assign,nonatomic)BOOL lzSelected;

- (void)reloadDataWithModel:(LZCartModel*)model;
- (void)numberAddWithBlock:(LZNumberChangedBlock)block;
- (void)numberCutWithBlock:(LZNumberChangedBlock)block;
- (void)cellSelectedWithBlock:(LZCellSelectedBlock)block;
@end

对这里的两个属性,需要简单的说明一下:

  • lzNumber :主要是提供给外部修改显示的商品数量,商品数量的变动,这次我放在cell内;一般情况下,外部需要和服务器交互,只有商品数量真正(服务器内记录的数据)发生变化了,才能去修改显示的数目,在上面的第二个和第三个方法的block内修改cell的这个属性即可,记得也要修改相应的数据模型;
  • lzSelected :主要是提供给外部修改该商品的选中状态,这次我将这个显示状态的变动放在了cell外部进行操作,同样是考虑到,外部要和服务器进行交互,只有商品真正(服务器记录的数据)添加到订单内,才能改变显示状态,同样在上面的第四个方法的block内修改这个属性即可,同样也要修改相应的数据模型;

PS:如果这两个量的变化不需要和服务器交互,直接在本地完成的,其显示状态可以直接在cell内部相应的点击方法里修改即可,外部只需修改相应的数据模型;


代码中,我设置了3个BOOL值:

BOOL _isHiddenNavigationBarWhenDisappear;//记录当页面消失时是否需要隐藏系统导航
BOOL _isHasTabBarController;//是否含有tabbar
BOOL _isHasNavitationController;//是否含有导航

作用后面都有注释,其中的第一个BOOL值需要简单说明一下: 因为我在控制器的viewWillAppearviewWillDisappear方法里做了一些判断,前者判断了当前控制器是否是属于导航,当是属于导航时,需要隐藏系统的导航条,因为有可能不会使用导航,所以我在这里自定义了导航条;后者在退出此视图时,需要把隐藏掉的导航再显示出来,但是这有个前提:使用了系统的导航,没有自定义,鉴于很多情况下都是使用自定义的导航,这时如果显示了系统导航,反而会弄巧成拙,所以第一BOOL值就是用来记录是否使用了系统导航的;

- (void)viewWillAppear:(BOOL)animated {
    
    if (_isHasNavitationController == YES) {
        if (self.navigationController.navigationBarHidden == YES) {
            _isHiddenNavigationBarWhenDisappear = NO;
        } else {
            self.navigationController.navigationBarHidden = YES;
            _isHiddenNavigationBarWhenDisappear = YES;
        }
    }
  }
- (void)viewWillDisappear:(BOOL)animated {
    if (_isHiddenNavigationBarWhenDisappear == YES) {
        self.navigationController.navigationBarHidden = NO;
    }
}
价格计算

价格的计算,这里我是直接遍历已选择的数组,取出其中的Model来计算的:

/**
 *  @author LQQ, 16-02-18 11:02:16
 *
 *  计算已选中商品金额
 */
-(void)countPrice {
    double totlePrice = 0.0;
    
    for (LZCartModel *model in self.selectedArray) {
        
        double price = [model.price doubleValue];
        
        totlePrice += price*model.number;
    }
    self.totlePriceLabel.text = [NSString stringWithFormat:@"%.2f",totlePrice];
}

使用

使用的时候直接将demo中的LZCartViewController文件夹下的文件拖进工程即可,注意不能直接使用,要根据自己的需求修改;

关于控制器LZCartViewController

建议直接使用我这个控制器LZCartViewController,里面我根据功能划分了几个区域,界面的东西修改为自己需要的,逻辑部分可以不用做太大的修改,添加上与服务器的交互及验证逻辑即可;

关于数据模型LZCartModel

数据模型这里肯定是要根据自己的需求进行定制的,这里我创建的模型是这样的:

@interface LZCartModel : NSObject
//自定义模型时,这三个属性必须有
@property (nonatomic,assign) BOOL select;
@property (nonatomic,assign) NSInteger number;
@property (nonatomic,copy) NSString *price;
//下面的属性可根据自己的需求修改
@property (nonatomic,copy) NSString *sizeStr;
@property (nonatomic,copy) NSString *nameStr;
@property (nonatomic,copy) NSString *dateStr;
@property (nonatomic,retain)UIImage *image;

@end

需要注意的是,demo中的模型前三个属性,是必须要有的,一般购物车也都有这些属性,如果不想改动太多,建议使用和我一样的命名

  • select:用来记录当前数据是否被选中;
  • number和price:用来计算总价;
关于自定义单元格LZCartTableViewCell

建议直接修改界面布局为自己项目的设计,里面大部分的逻辑是不需要动的,除非你把网络请求的一些东西放到cell中来了; .h文件内的属性和方法,建议不要修改,可以直接使用;

关于ConfigFile文件夹

里面有三个文件,一个是UIView的扩展类目;一个是头文件,保存一些公共的宏定义和全局变量;

效果图

效果图 增加分组效果图

总结

购物车的逻辑其实并不复杂,重构这个demo也花了不少时间,希望对你能有所帮助,使用过程中如果有bug,或者功能上错误,或者一些新功能,或者其他的建议,请可以联系我302934443;

如果对你有帮助,欢迎右上角star或者fork

本人CSDN博客,欢迎访问,一同学习!!!!
简书地址,目前文章还不多,慢慢的会发一些学习总结,欢迎关注!

About

比较完整的购物车界面及逻辑,商品展示,多选,单选,全选及滑动删除,价格计算;

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published