iOS WKWebView添加网页加载进度条

作者: Jixin | 来源:发表于2016-07-26 14:37 被阅读9954次

一、效果展示

WKWebProgressViewDemo.gif

二、主要步骤

1.添加UIProgressView属性

@property (nonatomic, strong) WKWebView *wkWebView;
@property (nonatomic, strong) UIProgressView *progressView;

2.初始化progressView

- (void)viewDidLoad {
    [super viewDidLoad];    
    //进度条初始化
    self.progressView = [[UIProgressView alloc] initWithFrame:CGRectMake(0, 20, [[UIScreen mainScreen] bounds].size.width, 2)];
    self.progressView.backgroundColor = [UIColor blueColor];
    //设置进度条的高度,下面这句代码表示进度条的宽度变为原来的1倍,高度变为原来的1.5倍.
    self.progressView.transform = CGAffineTransformMakeScale(1.0f, 1.5f);
    [self.view addSubview:self.progressView];
}

3.添加KVO,WKWebView有一个属性estimatedProgress,就是当前网页加载的进度,所以监听这个属性。

[self.wkWebView addObserver:self forKeyPath:@"estimatedProgress" options:NSKeyValueObservingOptionNew context:nil];

4.在监听方法中获取网页加载的进度,并将进度赋给progressView.progress

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSString *,id> *)change context:(void *)context {
    if ([keyPath isEqualToString:@"estimatedProgress"]) {
        self.progressView.progress = self.wkWebView.estimatedProgress;
        if (self.progressView.progress == 1) {
            /*
             *添加一个简单的动画,将progressView的Height变为1.4倍,在开始加载网页的代理中会恢复为1.5倍
             *动画时长0.25s,延时0.3s后开始动画
             *动画结束后将progressView隐藏
             */
            __weak typeof (self)weakSelf = self;
            [UIView animateWithDuration:0.25f delay:0.3f options:UIViewAnimationOptionCurveEaseOut animations:^{
                weakSelf.progressView.transform = CGAffineTransformMakeScale(1.0f, 1.4f);
            } completion:^(BOOL finished) {
                weakSelf.progressView.hidden = YES;

            }];
        }    
    }else{
        [super observeValueForKeyPath:keyPath ofObject:object change:change context:context];
    }
}

5.在WKWebViewd的代理中展示进度条,加载完成后隐藏进度条

//开始加载
- (void)webView:(WKWebView *)webView didStartProvisionalNavigation:(WKNavigation *)navigation {
    NSLog(@"开始加载网页");
    //开始加载网页时展示出progressView
    self.progressView.hidden = NO;
    //开始加载网页的时候将progressView的Height恢复为1.5倍
    self.progressView.transform = CGAffineTransformMakeScale(1.0f, 1.5f);
    //防止progressView被网页挡住
    [self.view bringSubviewToFront:self.progressView];
}

//加载完成
- (void)webView:(WKWebView *)webView didFinishNavigation:(WKNavigation *)navigation {
    NSLog(@"加载完成");
    //加载完成后隐藏progressView
    //self.progressView.hidden = YES;
}

//加载失败
- (void)webView:(WKWebView *)webView didFailProvisionalNavigation:(WKNavigation *)navigation withError:(NSError *)error {
    NSLog(@"加载失败");
    //加载失败同样需要隐藏progressView
    //self.progressView.hidden = YES;
}

6.在dealloc中取消监听

- (void)dealloc {
    [self.wkWebView removeObserver:self forKeyPath:@"estimatedProgress"];
}

三、github 代码地址

请戳这里查看demo,如果觉得还不错请随手给个star。

相关文章

网友评论

  • Jacky__燊:您好,请问我问什么改进度条的backgroundColor为greenColor运行出来还是blueColor,我下载了您的代码改了颜色运行之后还是blue的
    Jixin:改变进度条的颜色,设置progressTintColor颜色,如果也想改变右侧的颜色,设置trackTintColor
  • 大火柴丶:__weak typeof (self)weakSelf = self;
    [UIView animateWithDuration:0.25f delay:0.3f options:UIViewAnimationOptionCurveEaseOut animations:^{
    weakSelf.progressView.transform = CGAffineTransformMakeScale(1.0f, 1.4f);
    } completion:^(BOOL finished) {
    weakSelf.progressView.hidden = YES;

    }];

    这里是不需要 weakSelf的,直接用self就可以
  • seanward:为什么把web加载失败回调中的隐藏给注释了?
  • 至恒之狐:在吗?为什么我使用你的Demo,只会一次加载,而我把源码直接copy进来会发现,两次加载。是什么原因了
    Jixin:你把代码上传到GitHub,我看看吧
    至恒之狐:@Jixin 我直接把你那个控制器放到我项目中会出现两次,拿出来只执行一次,我找了很久也没找到原因,只是有的地址,想百度的只运行一次
    Jixin:网页加载两次的话,检查下面两个地方:
    1. 你看一下 startLoad 方法是否多次调用;
    2. loadRequest 方法是否多次调用。
  • 清风徐来花满楼:楼主上边的代码很好用赞一个,但是有一个问题就是你在观察者模式的代理方法中使用的动画没有起到作用,经常性的就是进度条加载了很短的时间就消失了,但是这时候页面还没有加载完成,所以用户在动画消失之后基本上还要等待一段时间,体验感很不好,所以,我把动画中的隐藏进度条的那行代码隐藏,在wkwebview的代理中隐藏加载进度条,感觉好了一点!
  • 语安月月鸟:很好用:+1:
  • 闲云悠鹤蝶恋舞:在完成的方法里面隐藏进度条的话,如果网速好的话,会出现进度条走不完就被隐藏了,楼主有好的方法解决吗?
    Jixin:@闲云悠鹤蝶恋舞 不客气。
    闲云悠鹤蝶恋舞:@Jixin 嗯嗯,好的,谢谢:+1:
    Jixin:@闲云悠鹤蝶恋舞 可以给进度条添隐藏的时候加一个animation。动画详情我已经在文章中的第四步和第五步中更新了,github上的代码同样做了更新。
  • 三笠_Ackerman:有demo吗?
    三笠_Ackerman:@Jixin 谢谢
    Jixin:@三笠_Ackerman demo链接 https://github.com/JixinZhang/WKWebProgressViewDemo
    Jixin:@三笠_Ackerman 周末我会写一个demo,到时候@你一下。

本文标题:iOS WKWebView添加网页加载进度条

本文链接:https://www.haomeiwen.com/subject/hcvnjttx.html