一个逻辑清晰的购物车模型

Marie0192 7年前
   <h2>效果图</h2>    <p style="text-align:center"><img src="https://simg.open-open.com/show/f997956442c88ec2be9cfc9b76153e8b.gif"></p>    <p style="text-align: center;">2017-03-25 18.28.23.gif</p>    <h2>说明</h2>    <p>这是一个具备常规功能并方便改造的购物车模型 一共包含五个模块:</p>    <ul>     <li>JVShopcartViewController : 购物车控制器 负责协调Model和View 只有100多行代码</li>     <li>JVShopcartFormat : 负责网络请求与逻辑处理</li>     <li>JVShopcartTableViewProxy : 作为控制器里边TableView的代理</li>     <li>View : 包括Cell、HeaderView、CountView(改变商品数的视图)、BottomView(控制器底部包含结算按钮的视图)</li>     <li>Model : 包含BrandModel和ProductModel两层</li>    </ul>    <h2>使用</h2>    <p>首先将工程里边的JVShopcart文件夹拖入你的项目 然后就是开源库Vendor文件夹根据需求处理 Model是一定会改的 但是购物车的Model大同小异 其他的改动不会太大</p>    <p>关于 JVShopcartViewController ,由于其遵循JVShopcartFormatDelegate协议,而协议里边的方法都是用 @required 修饰的,所以必须要实现它;下面依次介绍这些方法:</p>    <pre>  <code class="language-objectivec">- (void)shopcartFormatRequestProductListDidSuccessWithArray:(NSMutableArray *)dataArray;  - (void)shopcartFormatAccountForTotalPrice:(float)totalPrice                                  totalCount:(NSInteger)totalCount                               isAllSelected:(BOOL)isAllSelected;  - (void)shopcartFormatSettleForSelectedProducts:(NSArray *)selectedProducts;  - (void)shopcartFormatHasDeleteAllProducts;</code></pre>    <ul>     <li>这是请求购物车列表成功之后的回调方法,将装有Model的数组回调到控制器;控制器将其赋给TableView的代理类 JVShopcartTableViewProxy 并刷新TableView。</li>     <li>这是用户在操作了单选、多选、全选、删除这些会改变底部结算视图里边的全选按钮状态、商品总价和商品数的统一回调方法,这条API会将用户操作之后的结果,也就是是否全选、商品总价和和商品总数回调给 JVShopcartViewController , 控制器拿着这些数据调用底部结算视图BottomView的configure方法并刷新TableView,就完成了UI更新。</li>     <li>这是用户点击结算按钮的回调方法,这条API会将剔除了未选中ProductModel的模型数组回调给 JVShopcartViewController ,但并不改变原数据源因为用户随时可能返回。</li>     <li>这是用户删除了购物车所有数据之后的回调方法,你可能会做些视图的隐藏或者提示。</li>    </ul>    <p>关于 JVShopcartFormat ,这个类主要负责网络请求与逻辑处理以及结果的回调。下面依次介绍这些方法:</p>    <pre>  <code class="language-objectivec">- (void)requestShopcartProductList;  - (void)selectProductAtIndexPath:(NSIndexPath *)indexPath isSelected:(BOOL)isSelected;  - (void)selectBrandAtSection:(NSInteger)section isSelected:(BOOL)isSelected;  - (void)changeCountAtIndexPath:(NSIndexPath *)indexPath count:(NSInteger)count;  - (void)deleteProductAtIndexPath:(NSIndexPath *)indexPath;  - (void)starProductAtIndexPath:(NSIndexPath *)indexPath;  - (void)selectAllProductWithStatus:(BOOL)isSelected;  - (void)settleSelectedProducts;</code></pre>    <ul>     <li>这是请求购物车数据源的方法,大家一般都是对AFNetworking进行二次封装来请求数据。</li>     <li>这是用户选中了某个产品或某个row的处理方法,因为这会改变底部结算视图所以一定会回调上文协议中的第二个方法, 下同。</li>     <li>这是用户选中了某个品牌或某个section的处理方法</li>     <li>这是用户改变了商品数量的处理方法</li>     <li>这是用户删除操作的处理方法</li>     <li>这是用户收藏操作的处理方法,这里没有回调任何方法,也可以根据需求添加回调方法。</li>     <li>这是用户结算操作的处理方法</li>    </ul>    <h2>有几个点需要注意:</h2>    <ul>     <li>BrandModel里边有两个成员变量是手动添加进去的:isSelected和selectedArray前者是为了记录某个品牌或者说某个section是否被选中 后者是结算的时候记录选中的商品</li>     <li>ProductModel里边的isSelected也是手动添加的 也是为了记录某个商品或者说某个row是否被选中</li>     <li>Vendor文件夹里边是一些开源库 布局依赖Masonry 字典转模型依赖MJExtension 图片异步加载依赖SDWebImage 键盘的管理依赖IQKeyboardManager 当然你也可以自己处理</li>     <li>View里边的回调都是用的Block JVShopcartFormat里边的回调都是用的delegate 你也可以根据需求自行选择具体的回调方式</li>     <li>虽然购物车大同小异 但是总有些奇葩的需求需要自己去处理 肯定是要根据我的注释去做一些修改的</li>    </ul>    <p> </p>    <p>项目主页:<a href="http://www.open-open.com/lib/view/home/1490683874359">http://www.open-open.com/lib/view/home/1490683874359</a></p>    <p> </p>