swift版webview加载网页进度条效果
2017-11-08 10:45
627 查看
本文实例为大家分享了swift版webview加载网页展示的具体代码,供大家参考,具体内容如下
比较简单,直接上代码
import UIKit import WebKit import SnapKit class CMWebVC: UIViewController , WKNavigationDelegate { var webUrl: String? var webView: WKWebView =WKWebView() var progressView:UIProgressView = UIProgressView() var closeBtn: UIButton! override func initVC() { webView.addObserver(self, forKeyPath:"estimatedProgress", options: NSKeyValueObservingOptions.new, context:nil) webView.navigationDelegate =self } deinit { webView.removeObserver(self, forKeyPath:"estimatedProgress") webView.navigationDelegate =nil } override func viewDidLoad() { super.viewDidLoad() // webview view.addSubview(webView) webView.snp.makeConstraints { (make)in make.width.height.equalToSuperview() } // progressview view.addSubview(progressView) progressView.snp.makeConstraints { (make)in make.width.equalToSuperview() make.height.equalTo(3) make.top.equalToSuperview() } progressView.tintColor =UIColor.ColorBgTheme() progressView.isHidden =true // load url if webUrl !=nil { webView.load(URLRequest(url:URL(string: webUrl!)!)) } // shear self.showRightItem(image:"nav_share") { } } override func viewWillAppear(_ animated:Bool) { super.viewWillAppear(animated) self.closeButton() } override func viewWillDisappear(_ animated:Bool) { self.closeBtn.removeFromSuperview() } func closeButton() { if self.closeBtn ==nil { self.closeBtn =UIButton(frame: CGRect(x:44, y: 0, width:44, height: 44)) self.closeBtn.setTitle("关闭", for: .normal) self.closeBtn.setTitleColor(UIColor.black, for: .normal) self.closeBtn.addAction({ (button)in self.navigationController!.popViewController(animated:true) }) self.navigationController?.navigationBar.addSubview(self.closeBtn) } } override func observeValue(forKeyPath keyPath:String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?) { // 加载进度 if keyPath == "estimatedProgress" { let newprogress = change?[.newKey]!as! Float let oldprogress = change?[.oldKey]as? Float ??0.0 //不要让进度条倒着走...有时候goback会出现这种情况 if newprogress < oldprogress { return } if newprogress == 1 { progressView.isHidden =true progressView.setProgress(0, animated:false) } else { progressView.isHidden =false progressView.setProgress(newprogress, animated:true) } } } func webView(_ webView:WKWebView, didFinish navigation: WKNavigation!) { progressView.isHidden =true progressView.setProgress(0, animated:false) } func webView(_ webView:WKWebView, didFail navigation: WKNavigation!, withError error: Error) { progressView.isHidden =true progressView.setProgress(0, animated:false) } override func navigateBack() { if webView.canGoBack { webView.goBack() } else { super.navigateBack() } } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- swift版webview加载网页(带进度条)
- 仿微信中加载网页时带线行进度条的WebView的实现
- 仿微信中加载网页时带线行进度条的WebView的实现
- Android中WebView在加载网页的时候,怎样应用本地的CSS效果?就是说怎样把本地的CSS嵌入到HTML中
- webview设置网页加载进度条和设置点击返回键
- webview加载网页添加进度条的展示
- 仿微信中加载网页时带线行进度条的WebView的实现
- iOS 8 WkWebView 网页的配置和前进,后退,js 交互和进度条的加载
- iOS 8 WkWebView 网页的配置和前进,后退,js 交互和进度条的加载
- 仿微信中加载网页时带线行进度条的WebView的实现
- IOS swift使用webView加载网页上传文件报错:whose view is not in the window hierarchy!
- 仿微信中加载网页时带线行进度条的WebView的实现
- android webview 加载显示网页加载进度条的例子
- 网页或文件加载Loading进度条效果之三
- 在代码修改textview的Drawable 和 使用webview 加载网页
- Swift加载带导航条的WebView
- Swift - 加载webview进度条
- Android使用WebView加载网页
- webview加载网页空白或者不全的问题
- android中WebView加载网页设置进度条