Функция загрузки содержимого WKWebView никогда не вызывается

я пытаюсь получить функцию, вызываемую после того, как мой контент внутри WKWebView полностью загружен. Я нашел функцию «didFinishNavigation» в документации Apple Swift WKNavigation.

func webView(webView: WKWebView!, didFinishNavigation navigation: WKNavigation!) {
    println("WebView content loaded.")
}

Но функция никогда не вызывается.

import UIKit
import WebKit

class ViewController: UIViewController WKNavigationDelegate {

   override func loadView() {
       super.loadView()

       self.webView = WKWebView(frame:self.containerView.frame, configuration: WKWebViewConfiguration())
       self.containerView.addSubview(webView!)
       self.containerView.clipsToBounds = true

   }

   override func viewDidLoad() {
       super.viewDidLoad()

       var url = NSURL(string:"http://google.com/")
       var req = NSURLRequest(URL:url)
       self.webView!.loadRequest(req)
   }

   func webView(webView: WKWebView!, didFinishNavigation navigation: WKNavigation!) {
       println("WebView content loaded.")
   }

}

person Darx    schedule 26.08.2014    source источник


Ответы (2)


Вы не устанавливаете navigationDelegate. Ставь и должно быть нормально.

class ViewController: UIViewController, WKNavigationDelegate {


  override func viewDidLoad() {
    super.viewDidLoad()

    let noLayoutFormatOptions = NSLayoutFormatOptions(rawValue: 0)

    let webView = WKWebView(frame: CGRectZero, configuration: WKWebViewConfiguration())
    webView.setTranslatesAutoresizingMaskIntoConstraints(false)
    webView.navigationDelegate = self
    view.addSubview(webView)

    view.addConstraints(NSLayoutConstraint.constraintsWithVisualFormat("V:|[webView]|", options: noLayoutFormatOptions, metrics: nil, views: ["webView": webView]))

    view.addConstraints(NSLayoutConstraint.constraintsWithVisualFormat("H:|[webView]|", options: noLayoutFormatOptions, metrics: nil, views: ["webView": webView]))

    let url = NSURL(string: "http://google.com")
    let request = NSURLRequest(URL: url)
    webView.loadRequest(request)
  }

  func webView(webView: WKWebView!, didFinishNavigation navigation: WKNavigation!) {
    print("Finished navigating to url \(webView.url)");
  }

}

А вот немного лучшая версия со Swift 3.

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        let configuration = WKWebViewConfiguration()
        let webView = WKWebView(frame: .zero, configuration: configuration)
        webView.translatesAutoresizingMaskIntoConstraints = false
        webView.navigationDelegate = self
        view.addSubview(webView)

        [webView.topAnchor.constraint(equalTo: view.topAnchor),
         webView.bottomAnchor.constraint(equalTo: view.bottomAnchor),
         webView.leftAnchor.constraint(equalTo: view.leftAnchor),
         webView.rightAnchor.constraint(equalTo: view.rightAnchor)].forEach  { anchor in
            anchor.isActive = true
        }

        if let url = URL(string: "https://google.com/search?q=westworld") {
            webView.load(URLRequest(url: url))
        }
    }

}

  extension ViewController: WKNavigationDelegate {

    func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
        print("Finished navigating to url \(webView.url)")
    }

}
person Sandeep    schedule 26.08.2014
comment
получить ошибку в обработчике WKWebView нет члена request, как узнать к какому запросу относится навигация? - person János; 27.09.2015
comment
allZeros теперь недействителен. Раньше это был способ присвоить пустое значение перечислению в более ранних версиях Swift. Я отредактировал ответ сейчас. Спасибо, что заметили это :) - person Sandeep; 13.10.2015
comment
Вы должны добавить configuration.preferences.javaScriptEnabled = true; к вашей конфигурации, иначе он не будет работать. - person applecrusher; 16.10.2016
comment
@applecrusher Я не думаю, что javascript нужно включать для работы делегата навигации. У вас есть правильная настройка проекта, где вы можете показать мне, что javascriptEnabled имеет значение true, чтобы иметь возможность запускать навигационный делегат. - person Sandeep; 16.10.2016
comment
@Сандип. Вы правы, вам это не нужно. Я допустил ошибку. Я хотел сказать, что вам нужно javaScriptCanOpenWindowsAutomatically = true (по крайней мере, в Xcode 8 для Swift 3) - person applecrusher; 16.10.2016
comment
@Сандип Ты прав. У меня сейчас есть 3 вкладки stackoverflow, и я думаю, что комментировал неправильный вопрос. Это необходимо только в том случае, если вы используете оповещения и подтверждаете внутри собственного приложения, что вам нужно это настроить. - person applecrusher; 16.10.2016
comment
Кто-нибудь может объяснить, почему делегаты навигации не работают нормально с flipkart.com? - person krishan kumar; 17.09.2019

Я сделал простую ошибку, не добавив подвид в свой вид.

view.addSubview(webView)

Я создал webView программно, вот полный код

1.. import WebKit

2.. функция viewDidLoad()

let request = URLRequest(url: url)
let webView = WKWebView(frame: view.frame)
view.addSubview(webView)
webView.navigationDelegate = self
webView.load(request)

3.. Реализовать расширение для методов делегата

  // MARK: WKWebView
extension ViewController: WKNavigationDelegate {
    
    func webView(_ webView: WKWebView, didStartProvisionalNavigation navigation: WKNavigation!) {
        print("Start Request")
    }
    
    func webView(_ webView: WKWebView, didFail navigation: WKNavigation!, withError error: Error) {
        print("Failed Request")
    }
    
    func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
        print("Finished Request")
    }
person Ashvin A    schedule 11.05.2021