简单的购物车功能实现

实现一个简单的购物车的功能,界面比较丑见笑了,主要是说一下实现的思路,写起来还是挺简单的。


购物车Demo.jpeg

大致的实现思路是:
1.model负责数据的存取
2.自定义的cell负责展示model中的数据
3.通过cell上的按钮点击事件获取到cell对应的model,然后更改数据再刷新界面


定义model类

首先定义一个model,用来存放cell需要显示的数据,这里为了简单只定义了三个必须的属性,具体的名称、图片等还需要根据需求来定

@interface PXYCargoModel : NSObject
//商品数量
@property (nonatomic, assign) int count;
//是否选中
@property (nonatomic, assign) BOOL isSelected;
//商品价格
@property (nonatomic, assign) float price;

@end

自定义cell

这个就按照需求去自定义就好了,主要是三个按钮和一个记录选中状态的Bool值

//减按钮
@property (nonatomic, strong) UIButton *minusButton;
//加按钮
@property (nonatomic, strong) UIButton *addButton;
//选中按钮
@property (nonatomic, strong) UIButton *selectButton;
//记录选中状态
@property (nonatomic, assign) BOOL isSelected;

封装一下用model给cell的属性赋值的方法:
- (void)configCellWithModel:(PXYCargoModel *)model{
//购买数量
self.countLabel.text = [NSString stringWithFormat:@"%d",model.count];
//商品价格
self.priceLabel.text = [NSString stringWithFormat:@"%.2f",model.price];
}
设置一下三个按钮的tag值,分别设定为100001、100002、100003。实现一个统一的响应事件,点击“选中按钮”时需要切换一下按钮图片:
- (void)buttonAction:(UIButton *)sender{
//点击选中按钮时需要切换图片
if (sender.tag == 100003) {
self.isSelected = !self.isSelected;
if (self.isSelected) {
[self.selectButton setImage:[UIImage imageNamed:@"selected_btn"] forState:UIControlStateNormal];
}else{
[self.selectButton setImage:[UIImage imageNamed:@"selected_btn2"] forState:UIControlStateNormal];
}
}
//调用代理方法
if (self.delegate && [self.delegate respondsToSelector:@selector(tableViewCell:didButtonClickedWithTag:)]) {
[self.delegate tableViewCell:self didButtonClickedWithTag:sender.tag];
}
}
这里边调用了一个自定义的一个代理方法,需要的参数为cell本身以及对应的按钮的tag值,这是当点击cell上的按钮时能获取到对应的model值的关键。
这是自定义cell的.h文件:

@class PXYTableViewCell;
@protocol PXYTableViewCellDelegate <NSObject>

- (void)tableViewCell:(PXYTableViewCell *)cell didButtonClickedWithTag:(NSInteger)tag;

@end

@interface PXYTableViewCell : UITableViewCell

@property (nonatomic, weak)id<PXYTableViewCellDelegate> delegate;

- (void)configCellWithModel:(PXYCargoModel *)model;

@end

定义ViewController

接下来定义一个控制器,用来展示cell,实现对应的逻辑。

    @interface PXYTableViewController ()    <PXYTableViewCellDelegate,UITableViewDataSource,UITableViewDelegate>
    //展示数据的tableView
    @property (nonatomic, strong) UITableView *tableView;
    //数据源数组
    @property (nonatomic, strong) NSMutableArray *dataArray;
    //页面底部总价Label
    @property (nonatomic, strong) UILabel *totalPriceLabel;
    //去结算按钮
    @property (nonatomic, strong) UIButton *jiesuanButton;
    @end

在ViewDidLoad里配置一下UI,制造几个model数据用于模拟 (实际的话model数据是由网络请求或读取本地存储而来) 。然后实现tableView的代理方法:
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
PXYTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"cellID" forIndexPath:indexPath];
cell.delegate = self;
cell.selectionStyle = UITableViewCellSelectionStyleNone;
PXYCargoModel *model = self.dataArray[indexPath.row];
[cell configCellWithModel:model];
return cell;
}
然后实现cell的代理方法,通过传入的cell来获取数组中对应的model对象,通过点击按钮来改变model中对应的值,然后根据是否被选中以及对应的个数、单价计算出总价:
- (void)tableViewCell:(PXYTableViewCell *)cell didButtonClickedWithTag:(NSInteger)tag{
//通过传入的cell来获取indexPath值
NSIndexPath *indexPath = [self.tableView indexPathForCell:cell];
//通过indexPath值获取到对应的model对象
PXYCargoModel *model = self.dataArray[indexPath.row];
switch (tag) {
//减号按钮点击,不能显示负数
case 100001:
model.count - 1 >= 0 ? model.count -= 1 : 0;
break;
//加号按钮点击
case 100002:
model.count += 1;
break;
//选中按钮点击
case 100003:
model.isSelected = !model.isSelected;
break;
default:
break;
}
//只有被选中的商品才算入总价
float total = 0.0;
for (PXYCargoModel *model in self.dataArray) {
if (model.isSelected) {
total = total + model.price * model.count;
}
}
self.totalPriceLabel.text = [NSString stringWithFormat:@"%.2f",total];
[self.tableView reloadData];

}

ok,一个基本的购物车的功能就实现了,关键点就是通过自定义的cell的代理方法,传入cell来获取到cell对应的数据。然后就是一个简单的MVC思想,cell负责显示model中的数据,点击按钮改变的是数据源,然后刷新界面。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容