iOS – 如何以编程方式创建WKWebView Back Button?

前端之家收集整理的这篇文章主要介绍了iOS – 如何以编程方式创建WKWebView Back Button?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试为我的iOS WKWebView应用程序创建一个后退按钮,这样当用户点击按钮时它会将它们带到之前的WKWebView页面.我已经找到了很多关于如何使用IB而不是直接代码的教程.这是我到目前为止:

原始ViewController.swift

import UIKit
import WebKit

class ViewController: UIViewController,WKNavigationDelegate {

    private var webView: WKWebView!

    let wv = WKWebView(frame: UIScreen.mainScreen().bounds) //needed for working webview

    self.webView = WKWebView(frame: frame)
    self.webView.navigationDelegate = self

    func rightbutton(text: String,action: Selector) {
        let rightButton = UIBarButtonItem(title: text,style: .Plain,target: self,action: action)
        self.navigationItem.rightBarButtonItem = rightButton
    }

    func action() {
        if self.webView.canGoBack {
            print ("Can go back")
            self.webView.goBack()
            self.webView.reload()

        } else {
            print ( "Can't go back")
        }
    }


    override func viewDidLoad() {
        super.viewDidLoad()
        guard let url =  NSURL(string: "http://communionchapelefca.org/app-home") else { return }
        wv.navigationDelegate = self
        wv.loadRequest(NSURLRequest(URL: url))
        view.addSubview(wv)


        webView.goBack()
        webView.reload()



        prefButton()
        //backButton()

        NSNotificationCenter.defaultCenter().addObserver(self,selector: "receiveNotification:",name: "BeaconServiceRegionEnter",object: nil)

        NSNotificationCenter.defaultCenter().addObserver(self,name: "BeaconServiceRegionUpdate",name: "BeaconServiceRegionExit",object: nil)

    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func prefButton () {
        let image = UIImage(named: "icon-pref128") as UIImage?
        let button   = UIButton(type: UIButtonType.Custom) as UIButton
        let screenSize: CGRect = UIScreen.mainScreen().bounds
        let screenWidth = screenSize.width
        let screenHeight = screenSize.height

        button.frame = CGRectMake(screenWidth * 0.85,screenHeight * 0.90,56,56) // (X,Y,Height,Width)
        button.setImage(image,forState: .Normal)
        button.addTarget(self,action: "buttonClicked:",forControlEvents:.TouchUpInside)
        self.view.addSubview(button)
    }

    func buttonClicked(sender:UIButton)
    {
        UIApplication.sharedApplication().openURL(NSURL(string: UIApplicationOpenSettingsURLString)!)
    }

    func receiveNotification(notification: NSNotification) {
        print(notification.userInfo)
    }

    func webView(webView: WKWebView,decidePolicyForNavigationAction navigationAction: WKNavigationAction,decisionHandler: (WKNavigationActionPolicy) -> Void) {
        if navigationAction.navigationType == .LinkActivated  {
            if let newURL = navigationAction.request.URL,host = newURL.host where !host.containsString("communionchapelefca.org") &&
                    UIApplication.sharedApplication().canOpenURL(newURL) {
                        if UIApplication.sharedApplication().openURL(newURL) {
                            print(newURL)
                            print("Redirected to browser. No need to open it locally")
                            decisionHandler(.Cancel)
                        } else {
                            print("browser can not url. allow it to open locally")
                            decisionHandler(.Allow)
                        }
            } else {
                print("Open it locally")
                decisionHandler(.Allow)
            }
        } else {
            print("not a user click")
            decisionHandler(.Allow)
        }
    }

}

有什么建议?提前致谢.

编辑:附加整个ViewController而不是代码片段.

编辑2:k8mil的答案很接近,因为他的答案没有加载初始网址.以下是他回答的唯一调整:

private func createWebView() {
        guard let url = NSURL(string: "http://communionchapelefca.org/app-home") else { return }
        let frame  = UIScreen.mainScreen().bounds // or different frame created using CGRectMake(x,y,width,height)
        self.webView = WKWebView(frame: frame)
        self.webView.navigationDelegate = self
        self.webView.loadRequest(NSURLRequest(URL: url))
        self.view.addSubview(self.webView)
    }

解决方法

尝试在WKWebView实例上调用webView.goBack()方法,而不是WKWebView.goBack().在goBack()之后,你可以调用webView.reload()方法来确保你在正确的页面上.

我编辑了一下你的代码

import UIKit
import WebKit

class ViewController: UIViewController,WKNavigationDelegate {

private var webView: WKWebView!

override func viewDidLoad() {
    super.viewDidLoad()
    guard let url = NSURL(string: "http://communionchapelefca.org/app-home") else {
        return
    }

    //create WebView and Back button
    createWebView()
    backButton()


    prefButton()


    NSNotificationCenter.defaultCenter().addObserver(self,object: nil)

    NSNotificationCenter.defaultCenter().addObserver(self,object: nil)

}


private func createWebView() {
    let frame  = UIScreen.mainScreen().bounds // or different frame created using CGRectMake(x,height)
    self.webView = WKWebView(frame: frame)
    self.webView.navigationDelegate = self
    self.view.addSubview(self.webView)
}

func addBackButton(text: String,action: Selector) {
    //this function will add Button on your navigation bar e

    let rightButton = UIBarButtonItem(title: text,action: action)
    self.navigationItem.rightBarButtonItem = rightButton
}


override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

func prefButton() {
    let image = UIImage(named: "icon-pref128") as UIImage?
    let button = UIButton(type: UIButtonType.Custom) as UIButton
    let screenSize: CGRect = UIScreen.mainScreen().bounds
    let screenWidth = screenSize.width
    let screenHeight = screenSize.height

    button.frame = CGRectMake(screenWidth * 0.85,Width)
    button.setImage(image,forState: .Normal)
    button.addTarget(self,forControlEvents: .TouchUpInside)
    self.view.addSubview(button)
}

func backButton() {
    let image = UIImage(named: "icon-back") as UIImage?
    let button = UIButton(type: UIButtonType.Custom) as UIButton
    let screenSize: CGRect = UIScreen.mainScreen().bounds
    let screenWidth = screenSize.width
    let screenHeight = screenSize.height

    button.frame = CGRectMake(screenWidth * 0.85,action: "customGoBack:",forControlEvents: .TouchUpInside)
    self.view.addSubview(button)
}

func customGoBack(sender: UIButton) {
    if self.webView.canGoBack {
        print("Can go back")
        self.webView.goBack()
        self.webView.reload()
    } else {
        print("Can't go back")
    }
}

func buttonClicked(sender: UIButton) {
    UIApplication.sharedApplication().openURL(NSURL(string: UIApplicationOpenSettingsURLString)!)
}

func receiveNotification(notification: NSNotification) {
    print(notification.userInfo)
}

func webView(webView: WKWebView,decisionHandler: (WKNavigationActionPolicy) -> Void) {
    if navigationAction.navigationType == .LinkActivated {
        if let newURL = navigationAction.request.URL,host = newURL.host where !host.containsString("communionchapelefca.org") &&
                UIApplication.sharedApplication().canOpenURL(newURL) {
            if UIApplication.sharedApplication().openURL(newURL) {
                print(newURL)
                print("Redirected to browser. No need to open it locally")
                decisionHandler(.Cancel)
            } else {
                print("browser can not url. allow it to open locally")
                decisionHandler(.Allow)
            }
        } else {
            print("Open it locally")
            decisionHandler(.Allow)
        }
    } else {
        print("not a user click")
        decisionHandler(.Allow)
    }
}

}

此外,您不需要另一个WKWebView实例,因为您之前已声明过:

private var webView:WKWebView!

所以没有必要:

wv.navigationDelegate = self
wv.loadRequest(NSURLRequest(URL: url))  
view.addSubview(wv)

对我来说它有效.

希望对你有帮助 :)

猜你在找的iOS相关文章