模仿淘宝商品详情上提加载显示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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

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

友情链接更多精彩内容