欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

IOS購物車界面實現(xiàn)效果示例

 更新時間:2017年02月15日 15:42:25   作者:qazws  
本篇文章主要介紹了IOS購物車界面實現(xiàn)效果示例,有需要了解的朋友可參考。希望此文章對各位有所幫助。

購物軟件不可避免有添加購物車的頁面,那么購物車功能是怎么實現(xiàn)的吶?這里提供一種簡單的思路,插入本地數(shù)據(jù)庫。

先看效果

頁面結(jié)構(gòu)

本頁面是由一個tableview和底部的底部的bottomView構(gòu)成

底部的bottomView上有按鈕,也可以添加其他屬性,比如總價格,總重量等參數(shù)。

代碼結(jié)構(gòu)


思路

看到這樣的需求,我想到的是插入本地數(shù)據(jù)庫,每一條數(shù)據(jù)都有對應的id和其他的例如價格等的參數(shù),根據(jù)id插入本地是一條可行的方法,為了避免刷新的時候選中的單元格和沒選中的單元格的復用,我們需要對按鈕做一點操作。

@interface CustomButton : UIButton
@property (nonatomic,assign)NSInteger indexPathRow;
@end

在這個GoodCell里面自定義協(xié)議,為了取到某一行的值。

最重要的是選中與沒選中的按鈕要顯示不同的顏色

#pragma mark - selectedBtnAction
-(void)selectedBtnAction:(CustomButton *)btn
{
  btn.selected=!btn.selected;
  [self.delegate GoodsCellDelegateWithIndexPath:btn.indexPathRow];
}

-(void)configWithModel:(GoodsModel *)model{
  self.model = model;
  if (model.btnIsSelected==YES) {
    [self.selectedBtn setImage:[UIImage imageNamed:@"sendcar_selected"] forState:UIControlStateNormal];
  }else{
    [self.selectedBtn setImage:[UIImage imageNamed:@"sendcar_unselected"] forState:UIControlStateNormal];
  }
  //運單號
  self.cardLabel.text = [NSString stringWithFormat:@"運單號:%@",self.model.Ticket_No];
}

控制器界面

代理協(xié)議的實現(xiàn)

#pragma mark - delegate
-(void)GoodsCellDelegateWithIndexPath:(NSInteger)indexPathRow
{

  GoodsModel *cacheModel = self.dataArr[indexPathRow];
  if (cacheModel.btnIsSelected) {
//    NSLog(@"YES==%@",cacheModel.Ticket_No);
    cacheModel.btnIsSelected = NO;
  } else {
//    NSLog(@"NO==%@",cacheModel.Ticket_No);
    cacheModel.btnIsSelected = YES;
  }
  //插入---刪除  反復切換
  [self.dataManager insertDataFromModel:cacheModel Ticket_No:cacheModel.Ticket_No];
   //每次執(zhí)行插入刪除操作就會刷新底部的車輛的按鈕
  [self reloadBottonViewUI];
  [self.tableView reloadRowsAtIndexPaths:@[[NSIndexPath indexPathForRow:indexPathRow inSection:0]] withRowAnimation:UITableViewRowAnimationNone];
}
#pragma mark - 刷新底部的選車的數(shù)量  reloadBottonViewUI
-(void)reloadBottonViewUI
{
  if ([self.dataManager getAllGoodsArrCount]>0) {
    [self.toSelectCarBtn setTitle:[NSString stringWithFormat:@"去發(fā)車(%ld)",(long)[self.dataManager getAllGoodsArrCount]] forState:UIControlStateNormal];
  }else{
    [self.toSelectCarBtn setTitle:@"去發(fā)車" forState:UIControlStateNormal];
  }
}

去往下個頁面需要選中的有數(shù)據(jù)

#pragma mark - 去選車
-(void)toSelectCarBtnAction
{
  if ([self.dataManager getAllGoodsArrCount]>0) {
    //do something
    [self showSingleAlertViewWith:self title:@"提示" message:@"do something"];
  }else{
    [self showSingleAlertViewWith:self title:@"提示" message:@"請選擇物品"];
  }
}

代碼下載:PurchuseCar_Demo_jb51.rar

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • iOS Xcode創(chuàng)建文件時自動生成的注釋方法

    iOS Xcode創(chuàng)建文件時自動生成的注釋方法

    下面小編就為大家分享一篇iOS Xcode創(chuàng)建文件時自動生成的注釋方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • iOS實現(xiàn)無限循環(huán)輪播圖效果

    iOS實現(xiàn)無限循環(huán)輪播圖效果

    這篇文章主要為大家詳細介紹了iOS實現(xiàn)無限循環(huán)輪播圖效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • 最新評論