先看效果图:
下面是代码(测试环境:Xcode8.2.1,模拟器是iPhone7,iOS10.2)
1:导入头文件
import <WebKit/WebKit.h> @property (strong, nonatomic) WKWebView *webView; @property (strong, nonatomic) UIProgressView *progressView;
** 2:初始化**
// 创建urlrequest11111 NSURL *url = [NSURL URLWithString:@"//www.greatytc.com/"]; NSURLRequest *request = [NSURLRequest requestWithURL:url]; // WKWebView初始化 self.webView = [[WKWebView alloc] initWithFrame:self.view.frame]; // 加载请求 [self.webView loadRequest:request]; [self.view addSubview:self.webView]; // KVO,监听webView属性值得变化(estimatedProgress,title为特定的key) [self.webView addObserver:self forKeyPath:@"estimatedProgress" options:NSKeyValueObservingOptionNew context:nil]; [self.webView addObserver:self forKeyPath:@"title" options:NSKeyValueObservingOptionNew context:nil]; // UIProgressView初始化 self.progressView = [[UIProgressView alloc] initWithProgressViewStyle:UIProgressViewStyleDefault]; self.progressView.frame = CGRectMake(0, 0, self.webView.frame.size.width, 2); self.progressView.trackTintColor = [UIColor clearColor]; // 设置进度条的色彩 self.progressView.progressTintColor = [UIColor magentaColor]; // 设置初始的进度,防止用户进来就懵逼了(微信大概也是一开始设置的10%的默认值) [self.progressView setProgress:0.1 animated:YES]; [self.webView addSubview:self.progressView];
3:完成监听方法
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context { if ([object isEqual:self.webView] && [keyPath isEqualToString:@"estimatedProgress"]) { // 进度条 CGFloat newprogress = [[change objectForKey:NSKeyValueChangeNewKey] doubleValue]; NSLog(@"打印测试进度值:%f", newprogress); if (newprogress == 1) { // 加载完成 // 首先加载到头 [self.progressView setProgress:newprogress animated:YES]; // 之后0.3秒延迟隐藏 __weak typeof(self) weakSelf = self; dispatch_after(dispatch_time(DISPATCH_TIME_NOW, 0.3 * NSEC_PER_SEC), dispatch_get_main_queue(), ^{ weakSelf.progressView.hidden = YES; [weakSelf.progressView setProgress:0 animated:NO]; }); } else { // 加载中 self.progressView.hidden = NO; [self.progressView setProgress:newprogress animated:YES]; } } else if ([object isEqual:self.webView] && [keyPath isEqualToString:@"title"]) { // 标题 self.title = self.webView.title; } else { // 其他 [super observeValueForKeyPath:keyPath ofObject:object change:change context:context]; } }