swift版webview加载网页进度条效果
时间:2019-04-08
本文章向大家介绍swift版webview加载网页进度条效果,主要包括swift版webview加载网页进度条效果使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文实例为大家分享了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() } } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- 自动类型安全的.NET标准REST库refit
- 实现WebSocket和WAMP协议的开源库WampSharp
- Centos下部署DRBD+NFS+Keepalived高可用环境记录
- jQuery方法position()与offset()区别
- 温故而知新:设计模式之桥接模式(Bridge)
- 温故而知新:设计模式之装饰模式(Decorator)
- 域名“宝贝”baby.cn以71万元价格结拍
- 温故而知新:设计模式之组合模式(Composite)
- ruby学习笔记(7)-闭包
- ruby学习笔记(6)-Array的使用
- centos7下部署iptables环境纪录(关闭默认的firewalle)
- ruby学习笔记(5)-模块module的运用
- linux系统root密码遗忘的情况下的解决办法
- ruby学习笔记(4)-动态修改类的属性
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Flutter基础widgets教程-ListTile篇
- 深入剖析 linux GCC 4.4 的 STL String
- Flutter基础widgets教程-MaterialApp篇
- 如何使用Visual Studio Code开发Django项目
- Flutter基础widgets教程-Padding篇
- Flutter基础widgets教程-Placeholder篇
- Flutter基础widgets教程-PopupMenuButton篇
- Python部署rad+xray自动化
- 2.建立第一个django项目与配置
- Flutter基础widgets教程-Radio篇
- Django中的QuerySet
- Python—requests模块详解
- python爬虫伪装请求头---fake-useragent
- Flutter基础widgets教程-RaisedButton篇
- 记一次 excel vba 参考手册爬虫实战,不必要的一次爬虫。