"How to retrieve an url from Firebase Database BEFORE load WebView in Swift?"



我正在构建一个以webView和Firebase作为数据库的应用程序。应该用于加载webView的 url 应该来自数据库。

我已经正确实现了webView和Firebase,但问题是我的webView没有加载数据库中的网址,而是在var声明中声明的url。

似乎 viewDidLoad 在数据库观察方法关闭之前优先调用方法 webView 加载

如果我查看控制台,我可以清楚地看到一切正常,但是应该用于加载webview的 url 是在加载后从数据库中检索webview......这应该在之前完成,因为我把检索方法放在之前......

class ViewController:  UIViewController {
    var dbRef: DatabaseReference!
    var nextUrl = "https://www.google.co.uk/"
    func retrieveUrl () {
        dbRef = Database.database().reference().child("EXAMPLE")
        dbRef.observe(.value) { (snapshot) in
            let value = snapshot.value as! NSDictionary
            let url = value["url"]!
            self.nextUrl = (url as! String)
            print (nextUrl)
        }
        print ("function observe is called")
    }
    override func viewDidLoad () {
        super.viewDidLoad()
        retrieveUrl()
        print ("webview is about to load")
        let request = URLRequest (url: URL(string: nextUrl)!)
        self.webView.load(request)
        self.webView.addObserver(self, forKeyPath: #keyPath(WKWebView.isLoading), options: .new, context: nil)
    }
}

在控制台中,我可以看到"webview 即将加载"在 nextUrl 之前打印...这对我来说很奇怪

你应该在 firebase 观察者的回调中加载 webView。

因为您在 firebase 网络调用它类似异步工作后立即加载 webView,所以 webView 尝试加载 nextUrl 是否为空,为了防止类似异步的行为,您必须等待 nextUrl,或者您应该在 firebase 回传中加载 webView像跟随一样做

class ViewController:  UIViewController {
    var dbRef: DatabaseReference!
    var nextUrl = "https://www.google.co.uk/"
    func retrieveUrl () {
        dbRef = Database.database().reference().child("EXAMPLE")
        dbRef.observe(.value) {
            (snapshot) in
            let value = snapshot.value as! NSDictionary
            let url = value["url"]!
            self.nextUrl = (url as! String)
            print (nextUrl)
            print ("webview is about to load")
            let request = URLRequest (url: URL(string: nextUrl)!)
            self.webView.load(request)
            self.webView.addObserver(self, forKeyPath: #keyPath(WKWebView.isLoading), options: .new, context: nil)
        }
        print ("function observe is called")
    }
    override func viewDidLoad () {
        super.viewDidLoad()
        retrieveUrl()

相关内容

  • 没有找到相关文章

最新更新