利用WKWebView實(shí)現(xiàn)類似微信一樣的加載網(wǎng)頁的進(jìn)度條

效果圖:

wkwebView.gif
  • 目前這個版本有一個問題:發(fā)現(xiàn),在加載百度的時候,如果有的網(wǎng)頁本身帶有導(dǎo)航欄,它的頂部的進(jìn)度條就無效了植阴,如果沒有,則可以實(shí)現(xiàn)類似于微信一樣的進(jìn)度條

實(shí)現(xiàn)代碼:

import UIKit
import WebKit

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        
        view.addSubview(webView)
        view.addSubview(progressView)
        view.addSubview(centerButton)
        
        webView.frame = view.bounds
        progressView.frame = CGRect(x: 0, y: 0, width: UIScreen.mainScreen().bounds.size.width, height: 2)
        centerButton.frame = CGRect(x: 0, y: 0, width: 100, height: 100)
        centerButton.center = view.center
        
        webView.addObserver(self, forKeyPath: "estimatedProgress", options: .New, context: nil)
        webView.addObserver(self, forKeyPath: "title", options: .New, context: nil)
        webView.addObserver(self, forKeyPath: "loading", options: .New, context: nil)
       
        
    }
    
    override func observeValueForKeyPath(keyPath: String?, ofObject object: AnyObject?, change: [String : AnyObject]?, context: UnsafeMutablePointer<Void>) {
        
        if keyPath == "estimatedProgress" {

            let progress = change!["new"] as! Float
            
            print(progress)
            
            if progress >= 1.0 {
                
                self.progressView.setProgress(progress, animated: true)
                
                UIView.animateWithDuration(0.3, delay: 0.3, options: .CurveEaseInOut, animations: { 
                    
                    self.progressView.alpha = 0.0
                    
                    }, completion: { (_) in
                        
                     self.progressView.setProgress(0.0, animated: false)
                })
            
            }else {
            
                self.progressView.alpha = 1.0
                self.progressView.setProgress(progress, animated: true)
            }
            
            
            
            
        }else if keyPath == "loading" {
        
        }
        else if keyPath == "title" {
        
            print(webView.title ?? "")
        }
    }
    
    @objc private func click() {
    
         webView.loadRequest(NSURLRequest(URL: NSURL(string: "https://www.baidu.com")!))
    }
    
    private lazy var webView:WKWebView = {
        
        let webView = WKWebView()
        webView.UIDelegate = self
        webView.navigationDelegate = self
        
        return webView
    }()
    
    private lazy var progressView:UIProgressView = {
        
        let progressView = UIProgressView()
        progressView.trackTintColor = UIColor.whiteColor()
        progressView.progressTintColor = UIColor.greenColor()
        
        return progressView
    }()
    
    private lazy var centerButton:UIButton = {
        
        let centerButton = UIButton()
        centerButton.backgroundColor = UIColor.orangeColor()
        centerButton.addTarget(self, action: #selector(click), forControlEvents: .TouchUpInside)
        centerButton.setTitle("點(diǎn)擊一下", forState: .Normal)
        
        return centerButton
    }()

    deinit{
    
        removeObserver(self, forKeyPath: "estimatedProgress", context: nil)
        removeObserver(self, forKeyPath: "title", context: nil)
        removeObserver(self, forKeyPath: "loading", context: nil)
    }
}

extension ViewController : WKNavigationDelegate,WKUIDelegate {

    func webView(webView: WKWebView, decidePolicyForNavigationAction navigationAction: WKNavigationAction, decisionHandler: (WKNavigationActionPolicy) -> Void) {
    
        decisionHandler(.Allow)
    }
    
    func webView(webView: WKWebView, decidePolicyForNavigationResponse navigationResponse: WKNavigationResponse, decisionHandler: (WKNavigationResponsePolicy) -> Void) {
    
        decisionHandler(.Allow)
        
    }
    
    func webView(webView: WKWebView, didStartProvisionalNavigation navigation: WKNavigation!) {
    
    }
    
    func webView(webView: WKWebView, didReceiveServerRedirectForProvisionalNavigation navigation: WKNavigation!) {
    
    }
    
    //MARK: 加載失敗
    func webView(webView: WKWebView, didFailProvisionalNavigation navigation: WKNavigation!, withError error: NSError) {
    
    }
    
    //完成加載
    func webView(webView: WKWebView, didFinishNavigation navigation: WKNavigation!) {
    
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末圾浅,一起剝皮案震驚了整個濱河市掠手,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌狸捕,老刑警劉巖喷鸽,帶你破解...
    沈念sama閱讀 211,423評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異灸拍,居然都是意外死亡做祝,警方通過查閱死者的電腦和手機(jī)砾省,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,147評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來混槐,“玉大人纯蛾,你說我怎么就攤上這事∽莞簦” “怎么了?”我有些...
    開封第一講書人閱讀 157,019評論 0 348
  • 文/不壞的土叔 我叫張陵炮姨,是天一觀的道長捌刮。 經(jīng)常有香客問我,道長舒岸,這世上最難降的妖魔是什么绅作? 我笑而不...
    開封第一講書人閱讀 56,443評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮蛾派,結(jié)果婚禮上俄认,老公的妹妹穿的比我還像新娘。我一直安慰自己洪乍,他們只是感情好眯杏,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,535評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著壳澳,像睡著了一般岂贩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上巷波,一...
    開封第一講書人閱讀 49,798評論 1 290
  • 那天萎津,我揣著相機(jī)與錄音,去河邊找鬼抹镊。 笑死锉屈,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的垮耳。 我是一名探鬼主播颈渊,決...
    沈念sama閱讀 38,941評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼氨菇!你這毒婦竟也來了儡炼?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,704評論 0 266
  • 序言:老撾萬榮一對情侶失蹤查蓉,失蹤者是張志新(化名)和其女友劉穎乌询,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體豌研,經(jīng)...
    沈念sama閱讀 44,152評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡妹田,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,494評論 2 327
  • 正文 我和宋清朗相戀三年唬党,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鬼佣。...
    茶點(diǎn)故事閱讀 38,629評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡驶拱,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出晶衷,到底是詐尸還是另有隱情蓝纲,我是刑警寧澤,帶...
    沈念sama閱讀 34,295評論 4 329
  • 正文 年R本政府宣布晌纫,位于F島的核電站税迷,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏锹漱。R本人自食惡果不足惜箭养,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,901評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望哥牍。 院中可真熱鬧毕泌,春花似錦、人聲如沸嗅辣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽辩诞。三九已至坎弯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間译暂,已是汗流浹背抠忘。 一陣腳步聲響...
    開封第一講書人閱讀 31,978評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留外永,地道東北人崎脉。 一個月前我還...
    沈念sama閱讀 46,333評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像伯顶,于是被迫代替她去往敵國和親囚灼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,499評論 2 348

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,761評論 25 707
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫祭衩、插件灶体、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,060評論 4 62
  • 不知不覺大三下學(xué)期了,自己從來沒有像現(xiàn)在這么恐慌掐暮。
    風(fēng)華憂愁閱讀 103評論 0 0
  • 同樣一件衣服路克,為何她們又潮又有型仿佛雜志上走下來的模特樟结,而你卻總是穿的平庸失去了高級感呢养交?答案是:腳踝手腕鎖骨。 ...
    美呀小藝閱讀 310評論 0 0