ios开发加载webview显示进度条实例

发布时间 - 2026-01-11 01:10:06    点击率:

很多APP加载webView页面的时候都有进度条显示,今天我们这里主要使用相对轻量级的WKWebView加载网页,至于WKWebView 和UIWebView的区别与联系这里就不多讲了,自己百度哈哈。。。

WKWebView加载网页进度跳显示主要效果如下:

这里主要是使用KVO监听WKWebView的“estimatedProgress”属性,通过监听该属性的变化才是进度条的长度。

1、定义便利构造函数、以及属性和控件

var url: String?
  var progresslayer = CALayer()
  var webView: WKWebView?
  var button: UIButton?
convenience init(title: String, url: String) {
    self.init()
    self.title = title
    self.url = url
  }

2、创建webview控件,并监听estimatedProgress,进度条初始化的时候会给一定的长度显示(原因下面解释)。

func setupUI() {
    webView = WKWebView(frame: CGRect.init(x: 0, y: 0, width: screenWidth, height: screenHeight-64.0))

    if url == "" {
      url = "http:www.baidu.com"
    }
    let request = URLRequest(url: URL(string: url ?? "http:www.baidu.com")!)
    webView?.load(request)
    webView?.uiDelegate = self
    webView?.navigationDelegate = self;
    view.addSubview(webView!)

    //添加属性监听
    webView?.addObserver(self, forKeyPath: "estimatedProgress", options: .new, context: nil)
    progresslayer.frame = CGRect.init(x: 0, y: 0, width: screenWidth * 0.1, height: 3)
    progresslayer.backgroundColor = UIColor.green.cgColor
    view.layer.addSublayer(progresslayer)
  }

3、监听estimatedProgress属性变化,并修改进度条长度,创建进度条的时候之所以给一定的默认长度主要是因为在没有网络的状态下会立即进度float == 1条件,这样给人的感觉就是没有加载网页一样。

override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?) {
    if keyPath == "estimatedProgress" {
      progresslayer.opacity = 1
      let float = (change?[NSKeyValueChangeKey.newKey] as! NSNumber).floatValue
      progresslayer.frame = CGRect.init(x: 0, y: 0, width: (screenWidth * CGFloat(float)) , height: 3)
      if float == 1 {
        weak var weakself = self
        DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 0.2, execute: {
          weakself?.progresslayer.opacity = 0
        })
        DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 0.8, execute: {
          weakself?.progresslayer.frame = CGRect.init(x: 0, y: 0, width: 0, height: 3);
        })
      }
    }else{
      super.observeValue(forKeyPath: keyPath, of: object, change: change, context: context)
    }
  }

4、web view加载失败后提示

extension KKWebView : WKUIDelegate, WKNavigationDelegate {
  func webView(_ webView: WKWebView, didFailProvisionalNavigation navigation: WKNavigation!, withError error: Error) {
    guard let btn = button else {
      button = UIButton(type: .system)
      button?.frame = CGRect.init(x: 0, y: 3, width: screenWidth, height: screenHeight-64-3)
      button?.backgroundColor = UIColor.white
      button?.setTitleColor(UIColor.darkText, for: .normal)
      button?.setTitle("点击重新加载", for: .normal)
      button?.addTarget(self, action: #selector(loadURL), for: .touchUpInside)
      view.addSubview(button!)
      return
    }
    btn.isHidden = false
  }
}

5、记载失败后点击提示重新加载

 func loadURL() {
    button?.isHidden = true
    if url == "" {
      url = "http:www.baidu.com"
    }
    let request = URLRequest(url: URL(string: url ?? "http:www.baidu.com")!)
    webView?.load(request)
  }

5、移除监听,离开页面的时候需要移除KVO监听,否则会出现内存泄露

deinit {
    webView!.removeObserver(self, forKeyPath: "estimatedProgress")
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# ios  # webview  # 加载进度条  # 进度条  # ios加载webview进度条  # iOS开发中WebView的基本使用方法简介  # IOS中UIWebView加载Loading的实现方法  # IOS中的webView加载HTML  # 轻松理解iOS 11中webview的视口  # 详解iOS webview加载时序和缓存问题总结  # iOS Webview自适应实际内容高度的4种方法详解  # iOS 对当前webView进行截屏的方法  # iOS获取cell中webview的内容尺寸  # iOS去除Webview键盘顶部工具栏的方法  # 加载  # 移除  # 都有  # 是因为  # 才是  # 不多  # 给人  # 会给  # 讲了  # 则会  # 大家多多  # 主要是  # 状态下  # www  # baidu  # URLRequest  # request  # http  # width 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel安装步骤详细教程_Laravel环境搭建指南  Python文件操作最佳实践_稳定性说明【指导】  PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  Python企业级消息系统教程_KafkaRabbitMQ高并发应用  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例  php json中文编码为null的解决办法  如何用PHP快速搭建高效网站?分步指南  昵图网官网入口 昵图网素材平台官方入口  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  如何在阿里云香港服务器快速搭建网站?  米侠浏览器网页背景异常怎么办 米侠显示修复  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  如何用腾讯建站主机快速创建免费网站?  如何在Tomcat中配置并部署网站项目?  MySQL查询结果复制到新表的方法(更新、插入)  网站建设要注意的标准 促进网站用户好感度!  实例解析angularjs的filter过滤器  Python文本处理实践_日志清洗解析【指导】  个人摄影网站制作流程,摄影爱好者都去什么网站?  Laravel怎么为数据库表字段添加索引以优化查询  JS去除重复并统计数量的实现方法  高防服务器如何保障网站安全无虞?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  Claude怎样写结构化提示词_Claude结构化提示词写法【教程】  在线教育网站制作平台,山西立德教育官网?  微信小程序 HTTPS报错整理常见问题及解决方案  如何自定义建站之星模板颜色并下载新样式?  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  如何在不使用负向后查找的情况下匹配特定条件前的换行符  Laravel怎么调用外部API_Laravel Http Client客户端使用  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  微信小程序 wx.uploadFile无法上传解决办法  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  高端建站如何打造兼具美学与转化的品牌官网?  如何在IIS中新建站点并配置端口与物理路径?  Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  南京网站制作费用,南京远驱官方网站?  BootStrap整体框架之基础布局组件  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  油猴 教程,油猴搜脚本为什么会网页无法显示?  Laravel如何实现文件上传和存储?(本地与S3配置)  如何在云服务器上快速搭建个人网站?  如何基于云服务器快速搭建个人网站?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)