模仿淘宝商品详情上提加载显示WebView页面(附Demo源码地址)

GIF演示:


  • 前段时间逛淘宝的时候发现淘宝的商品详情页,上提显示WebView页面,下拉刷新显示浏览记录商品,于是就想模仿着写一下,我是利用 MJRefresh 来写的
    真的要感谢 MJRefresh 的作者,因为利用 MJRefresh 写会省掉很多代码,并且效果也特别好,
其实我写的这个特别简单,只能说在一些大神面前献丑了,实现淘宝的这个效果,首先要熟悉IOS的视图布局,了解UITableView、UIScrollView、UIWebView的基础,然后会使用MJRefresh和IOS动画即可;
希望各位多多提下意见,或者告诉我一些别的实现方式!谢谢大家

思路分析:

  • step1:
    设置一个__ UIScrollView__ 作为视图底层,并且设置分页为两页

  • step2:
    然后在第一个分页上添加一个__ UITableView__ 并且设置表格能够上提加载(上拉操作即为让视图滚动到下一页)

  • step3:
    在第二个分页上添加一个__ UIWebView__ 并且设置能有下拉刷新操作(下拉操作即为让视图滚动到上一页)

- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor whiteColor];
    //创建导航栏标题
    self.topTitleView = [[UILabel alloc] init];
    self.topTitleView.textAlignment = NSTextAlignmentCenter;
    self.topTitleView.text = @"导航栏标题-UITableView";
    self.topTitleView.backgroundColor = [UIColor colorWithRed:0.45f green:0.84f blue:1.00f alpha:1.00f];
    self.topTitleView.textColor = [UIColor blackColor];
    self.topTitleView.frame = CGRectMake(0, 0, IPHONE_W, 50);
    [self.view addSubview:self.topTitleView];
    
    //创建scrollPullViewiew
    self.scrollPullView = [[UIScrollView alloc]initWithFrame:CGRectMake(0,50, IPHONE_W, IPHONE_H-50)];
    self.scrollPullView.contentSize = CGSizeMake(IPHONE_W, (IPHONE_H-50) * 2);
    self.scrollPullView.pagingEnabled = YES;
    self.scrollPullView.backgroundColor = [UIColor whiteColor];
    //禁用滚动
    self.scrollPullView.scrollEnabled = NO;
    [self.view addSubview:self.scrollPullView];
    
    //创建上面的TableView
    self.tablePullView = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, IPHONE_W, IPHONE_H-50) style:UITableViewStylePlain];
    self.tablePullView.delegate = self;
    self.tablePullView.dataSource = self;
    self.tablePullView.backgroundColor = [UIColor whiteColor];
    [self.scrollPullView addSubview:self.tablePullView];
    
    //创建下面的webView
    self.webView = [[UIWebView alloc]initWithFrame:CGRectMake(0, IPHONE_H, IPHONE_W, IPHONE_H)];
    self.webView.backgroundColor = [UIColor whiteColor];
    [self.scrollPullView addSubview:self.webView];
    [self.webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@"http://www.baidu.com"]]];
    //设置UITableView 下拉刷新和上提加载
    [self.tablePullView addHeaderWithTarget:self action:@selector(tablePullViewHeaderRefrsh)];
    [self.tablePullView addFooterWithTarget:self action:@selector(tablePullViewFootRefrsh)];
    //设置UIWebView 下拉操作
    [self.webView.scrollView addHeaderWithTarget:self action:@selector(webViewHeaderRefrsh)];

}

  • step4:
    实现 UITableView 下拉刷新和上提显示 的方法

//UITableView 下拉头部刷新方法
-(void)tablePullViewHeaderRefrsh
{
    [self.tablePullView headerEndRefreshing];
}
//UITableView 上提刷新方法 显示WebView页面
-(void)tablePullViewFootRefrsh
{
    [UIView animateWithDuration:0.5 delay:0.0 options:UIViewAnimationOptionLayoutSubviews animations:^{
        self.scrollPullView.contentOffset = CGPointMake(0, IPHONE_H);
    } completion:^(BOOL finished) {
        //结束加载
        self.topTitleView.text = @"导航栏标题-WebView";
        [self.tablePullView footerEndRefreshing];
    }];

}



  • step5:
    实现 UIWebView 下拉的方法

//WebView 下拉显示头部试图
-(void)webViewHeaderRefrsh
{
    [UIView animateWithDuration:0.5 delay:0.0 options:UIViewAnimationOptionLayoutSubviews animations:^{
       self.scrollPullView.contentOffset = CGPointMake(0, 0);
    } completion:^(BOOL finished) {
        //结束加载
      self.topTitleView.text = @"导航栏标题-UITableView";
      [self.webView.scrollView headerEndRefreshing];
    }];
    
}

源码下载地址:http://www.code4app.com/thread-10751-1-1.html

图片发自简书App

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

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,086评论 4 62
  • “再见!” “再见……” 那年六月末的风啊,匆匆地来,送走了春最后一丝的清凉,送走了往昔校园里的朗朗书声,也毫不留...
    紫怜阅读 353评论 0 0
  • 饭足需休憩,嫣无入梦呓。 苍苍映莺莺,吾心不得欣!
    王今一阅读 88评论 0 0
  • 20几岁,是个适婚的年纪。随着年纪的增长,越来越多的同学朋友,渐渐完成了自己人生重要的一步,踏入婚姻。每每还处在单...
    依米Nina阅读 1,588评论 0 4
  • 简 以最真挚的方法 书 以最美好的形式 2017伊始,我在简书,即将开始简书文字。 希望我的文字,在属于文字的世界...
    我吃虾米阅读 184评论 1 2