亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS實現列表與網格兩種視圖的相互切換

2020-07-26 03:08:29
字體:
來源:轉載
供稿:網友

下圖為京東商城的截圖

很多人看到這個,第一眼想到的是用TableViewCollectionView來做切換,筆者剛開始也是認為這么做,后來發現還有一個非常的簡單方法,就可以實現這個功能。

實現代碼

1、首先創建一個CollectionView。

- (UICollectionView *)collectionView{  if (!_collectionView)  {    UICollectionViewFlowLayout *flowlayout = [[UICollectionViewFlowLayout alloc] init];    //設置滾動方向    [flowlayout setScrollDirection:UICollectionViewScrollDirectionVertical];    //左右間距    flowlayout.minimumInteritemSpacing = 2;    //上下間距    flowlayout.minimumLineSpacing = 2;    _collectionView = [[UICollectionView alloc] initWithFrame:CGRectMake(2 , 2 , self.view.bounds.size.width - 4, self.view.bounds.size.height - 4) collectionViewLayout:flowlayout];    _collectionView.delegate = self;    _collectionView.dataSource = self;    _collectionView.showsVerticalScrollIndicator = NO;    _collectionView.showsHorizontalScrollIndicator = NO;    [_collectionView setBackgroundColor:[UIColor clearColor]];    //注冊cell    [_collectionView registerClass:[GridListCollectionViewCell class] forCellWithReuseIdentifier:kCellIdentifier_CollectionViewCell];  }  return _collectionView;}

然后去京東商城抓取json數據,再去解析數據裝入模型,objectWithDictionary:是將字典轉化為模型,這個工具是我用 Runtime 寫的,一行代碼解析數據。

- (void)viewDidLoad {  [super viewDidLoad];  // Do any additional setup after loading the view, typically from a nib.  // 默認列表視圖  _isGrid = NO;  NSString *path = [[NSBundle mainBundle] pathForResource:@"product" ofType:@"json"];  NSData *data = [NSData dataWithContentsOfFile:path];  NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingAllowFragments error:nil];  [self.view addSubview:self.collectionView];  NSArray *products = dict[@"wareInfo"];  for (id obj in products) {    [self.dataSource addObject:[GridListModel objectWithDictionary:obj]];  }}

再去自定義CollectionViewCell,給cell添加一個屬性isGrid,用來判斷是列表還是格子視圖。

.h文件:

#import <UIKit/UIKit.h>#define kCellIdentifier_CollectionViewCell @"GridListCollectionViewCell"@class GridListModel;@interface GridListCollectionViewCell : UICollectionViewCell/** 0:列表視圖,1:格子視圖 */@property (nonatomic, assign) BOOL isGrid;@property (nonatomic, strong) GridListModel *model;@end

.m文件

#import "GridListCollectionViewCell.h"#import "GridListModel.h"#import "UIImageView+WebCache.h"#define ScreenWidth ([UIScreen mainScreen].bounds.size.width)@interface GridListCollectionViewCell ()@property (nonatomic, strong) UIImageView *imageV;@property (nonatomic, strong) UILabel *titleLabel;@property (nonatomic, strong) UILabel *priceLabel;@end@implementation GridListCollectionViewCell- (instancetype)initWithFrame:(CGRect)frame{  self = [super initWithFrame:frame];  if (self) {    [self configureUI];  }  return self;}- (void)configureUI{  _imageV = [[UIImageView alloc] initWithFrame:CGRectZero];  [self.contentView addSubview:_imageV];  _titleLabel = [[UILabel alloc] initWithFrame:CGRectZero];  _titleLabel.numberOfLines = 0;  _titleLabel.font = [UIFont boldSystemFontOfSize:14];  [self.contentView addSubview:_titleLabel];  _priceLabel = [[UILabel alloc] initWithFrame:CGRectZero];  _priceLabel.textColor = [UIColor redColor];  _priceLabel.font = [UIFont systemFontOfSize:16];  [self.contentView addSubview:_priceLabel];}- (void)setIsGrid:(BOOL)isGrid{  _isGrid = isGrid;  if (isGrid) {    _imageV.frame = CGRectMake(5, 5, self.bounds.size.width - 60, self.bounds.size.width - 60);    _titleLabel.frame = CGRectMake(5, self.bounds.size.width - 45, ScreenWidth/2, 20);    _priceLabel.frame = CGRectMake(5, self.bounds.size.width - 20, ScreenWidth/2, 20);  } else {    _imageV.frame = CGRectMake(5, 5, self.bounds.size.height - 10, self.bounds.size.height - 10);    _titleLabel.frame = CGRectMake(self.bounds.size.height + 10, 0, ScreenWidth/2, self.bounds.size.height - 20);;    _priceLabel.frame = CGRectMake(self.bounds.size.height + 10, self.bounds.size.height - 30, ScreenWidth/2, 20);;  }}- (void)setModel:(GridListModel *)model{  _model = model;  [_imageV sd_setImageWithURL:[NSURL URLWithString:model.imageurl]];  _titleLabel.text = model.wname;  _priceLabel.text = [NSString stringWithFormat:@"¥%.2f",model.jdPrice];}@end

再添加一個切換視圖的按鈕,按鈕的點擊事件如下:

#pragma mark - Action- (IBAction)onBtnClick:(id)sender{  _isGrid = !_isGrid;  [self.collectionView reloadData];  if (_isGrid) {    [self.swithBtn setImage:[UIImage imageNamed:@"product_list_grid_btn"] forState:0];  } else {    [self.swithBtn setImage:[UIImage imageNamed:@"product_list_list_btn"] forState:0];  }}

最后還要設置一下切換時的CollectionViewItemSize

- (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath{  if (_isGrid) {    return CGSizeMake((ScreenWidth - 6) / 2, (ScreenWidth - 6) / 2 + 40);  } else {    return CGSizeMake(ScreenWidth - 4, (ScreenWidth - 6) / 4 + 20);  }}

這樣子就大體實現了列表視圖和網格視圖的相互切換,是不是很簡單。

總結

以上就是這篇文章的全部內容了,可能由于筆者水平有限,文中如果有錯誤的地方,還望大家能夠指出?;蛘哂懈玫姆椒ê徒ㄗh,我們也可以一起交流。希望這篇文章的內容對大家能有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日产精品久久久一区二区福利| 久久久久久久久电影| 欧美剧在线观看| 欧美激情在线观看视频| 91精品国产99久久久久久| 亚洲成人黄色在线观看| 91精品免费久久久久久久久| yellow中文字幕久久| 久久大大胆人体| 国产精品视频午夜| 国产欧美久久一区二区| 欧美极品在线视频| 欧美精品久久久久a| 91在线精品视频| 亚洲欧洲视频在线| 欧洲成人免费视频| 亚洲国产99精品国自产| 日韩精品免费在线| 久久手机精品视频| 欧美老少做受xxxx高潮| 热99精品只有里视频精品| 一区二区三区动漫| 91高潮精品免费porn| 亚洲色图欧美制服丝袜另类第一页| 欧美精品videos另类日本| 欧美疯狂xxxx大交乱88av| 日韩精品福利网站| 久久久久久国产精品久久| 欧美交受高潮1| 一区二区三区高清国产| 茄子视频成人在线| 国产97在线|亚洲| 亚洲色图第一页| 精品久久久久久中文字幕| 人人做人人澡人人爽欧美| 国产精品视频色| 成人网在线免费观看| 欧美成人精品激情在线观看| 97国产精品人人爽人人做| 国产91精品最新在线播放| 欧洲亚洲妇女av| 精品露脸国产偷人在视频| 国产日韩中文在线| 国产精品欧美日韩久久| 成人久久18免费网站图片| 亚洲性69xxxbbb| 2018中文字幕一区二区三区| 夜夜嗨av色一区二区不卡| 日韩国产高清视频在线| 欧美一区二区三区免费视| 亚洲成人精品在线| 性亚洲最疯狂xxxx高清| 亚洲国产精品成人一区二区| 在线观看国产精品日韩av| 亚洲美女在线观看| 26uuu日韩精品一区二区| 国产激情综合五月久久| 亚洲一区二区三区四区视频| 欧美日韩另类字幕中文| 秋霞av国产精品一区| 日韩av日韩在线观看| 欧美极品第一页| 亚洲片国产一区一级在线观看| 久久久免费精品视频| 亚洲国产91精品在线观看| 欧美尺度大的性做爰视频| 日韩禁在线播放| 国产69精品久久久久99| 91久久国产综合久久91精品网站| 欧美激情视频网站| 国产成人黄色av| 中文字幕av一区二区三区谷原希美| 96pao国产成视频永久免费| 日韩欧美国产成人| 国产精品视频精品视频| 欧美放荡办公室videos4k| xxav国产精品美女主播| 福利一区视频在线观看| 久久这里只有精品视频首页| 国产精品久久久久久搜索| 欧美电影免费观看高清| 日韩中文字幕免费看| 亚洲人成电影在线播放| 亚洲无亚洲人成网站77777| 久久精品国产久精国产一老狼| 久久精品国产电影| 久久69精品久久久久久国产越南| 亚洲国产日韩欧美综合久久| 国产在线精品自拍| 日韩av网站导航| 亚洲国产成人久久综合| 91精品国产91久久| 成人xvideos免费视频| 国产欧美精品日韩| 亚洲欧美国内爽妇网| 91九色国产在线| 亚洲美女视频网| 国产精品国产福利国产秒拍| 亚洲国产美女久久久久| 色婷婷av一区二区三区在线观看| 91国内在线视频| 久久久久久国产精品久久| 黑人巨大精品欧美一区二区| 欧美性xxxxhd| 日韩视频免费观看| 亚洲视频自拍偷拍| 欧美成人三级视频网站| 91久久国产精品| 精品久久久久久中文字幕| 国产狼人综合免费视频| 91精品国产91久久| 成人在线一区二区| 国产美女91呻吟求| 亚洲精品国产综合久久| 欧美片一区二区三区| 在线看福利67194| 欧美激情视频三区| 成人日韩在线电影| 色偷偷888欧美精品久久久| 成人综合网网址| 成人h猎奇视频网站| 伊人久久综合97精品| 亚洲高清色综合| 91成人天堂久久成人| 在线观看欧美成人| 欧美又大粗又爽又黄大片视频| 国产丝袜精品视频| 亚洲高清久久久久久| 欧美做受高潮1| 国产精品久久久久久久久| 亚洲一区二区在线| 欧美人与性动交| 欧美另类老肥妇| 亚洲欧美成人网| 亚洲女人天堂色在线7777| 国产精品成人av在线| 国产精品三级美女白浆呻吟| 国产欧美婷婷中文| 国产精品自在线| 成人国产精品久久久| 欧美精品videossex88| 亚洲电影成人av99爱色| 精品伊人久久97| 欧美成人中文字幕| www国产精品com| 日韩电影免费观看在线观看| 国产视频精品自拍| 中文字幕综合在线| 亚洲免费福利视频| 播播国产欧美激情| 成人激情在线播放| 欧美午夜久久久| 亚洲色图25p| 中文字幕av一区中文字幕天堂| 中文字幕日韩精品在线观看| 国内精品久久久久影院 日本资源| 成人久久久久久久| 久久精品电影网站| 亚洲97在线观看| 日韩精品视频在线观看免费| 国产精品吹潮在线观看| 亚洲成人教育av| 91伊人影院在线播放| 最近更新的2019中文字幕|