简体   繁体   English

在UIWebView中向后/向前滑动手势?

[英]Swipe gesture for back/forward in UIWebView?

I have a WebView in my app. 我的应用程序中有一个WebView。

Because it is a tabbed application I'm not able to add buttons for going back/forward on the website. 因为它是一个标签式应用程序,所以我无法在网站上添加用于返回/转发的按钮。

I want to go back/forward by swiping. 我想通过滑动返回/前进。 Right swipe from the left side/edge is back… like in Safari browser for iOS. 右侧滑动从左侧/边缘返回...就像在iOS浏览器浏览器中一样。

How can I do it? 我该怎么做? I think i should use "Screen Edge Pan Gesture Recognizer", right? 我想我应该使用“Screen Edge Pan Gesture Recognizer”,对吗?

Accepted answer in Swift 3: Swift 3中接受的答案:

override func viewDidLoad() {
    super.viewDidLoad()

    let swipeLeftRecognizer = UISwipeGestureRecognizer(target: self, action: #selector(handleSwipe(recognizer:)))
    let swipeRightRecognizer = UISwipeGestureRecognizer(target: self, action: #selector(handleSwipe(recognizer:)))
    swipeLeftRecognizer.direction = .left
    swipeRightRecognizer.direction = .right

    webView.addGestureRecognizer(swipeLeftRecognizer)
    webView.addGestureRecognizer(swipeRightRecognizer)
}

@objc private func handleSwipe(recognizer: UISwipeGestureRecognizer) {
    if (recognizer.direction == .left) {
        if webView.canGoForward {
            webView.goForward()
        }
    }

    if (recognizer.direction == .right) {
        if webView.canGoBack {
            webView.goBack()
        }
    }
}

Answer in Swift 3 & Swift 4 在Swift 3和Swift 4中回答

If anyone is still having problems. 如果有人还有问题。 This worked for me: 这对我有用:

Find "didFinish" add / replace the following code. 查找“didFinish”添加/替换以下代码。

func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {

    self.didFinish()

    webView.allowsBackForwardNavigationGestures = true

}

The main code you need is just one line. 您需要的主要代码只有一行。 It comes after self.didFinish() but still within the {} brackets. 它位于self.didFinish()之后,但仍位于{}括号内。

webView.allowsBackForwardNavigationGestures = true webView.allowsBackForwardNavigationGestures = true

Why not just use a swipe gesture recognizer? 为什么不使用滑动手势识别器?

UISwipeGestureRecognizer *swipeLeft = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(handleSwipe:)];
UISwipeGestureRecognizer *swipeRight = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(handleSwipe:)];

// Setting the swipe direction.
[swipeLeft setDirection:UISwipeGestureRecognizerDirectionLeft];
[swipeRight setDirection:UISwipeGestureRecognizerDirectionRight];

// Adding the swipe gesture on WebView
[webView addGestureRecognizer:swipeLeft];
[webView addGestureRecognizer:swipeRight];

- (void)handleSwipe:(UISwipeGestureRecognizer *)swipe {

if (swipe.direction == UISwipeGestureRecognizerDirectionLeft) {
    NSLog(@"Left Swipe");
}

if (swipe.direction == UISwipeGestureRecognizerDirectionRight) {
    NSLog(@"Right Swipe");   
} 

}

Gabriel Madruga's answer worked for me. Gabriel Madruga的回答对我有用。 I reduced the lines of code further by: 我进一步减少了代码行:

  1. Drag and drop a WebView into the storyboard. 将WebView拖放到故事板中。 Apply required constraints. 应用所需的约束。
  2. Declare the IBOutlet of the WebView. 声明WebView的IBOutlet。 I named it webViewBox. 我把它命名为webViewBox。
  3. Import WebKit framework. 导入WebKit框架。 (import WebKit) (导入WebKit)
  4. Add the following lines of code in viewDidLoad() 在viewDidLoad()中添加以下代码行

     let leftSwipe = UISwipeGestureRecognizer(target: webViewBox, action: #selector(webViewBox.goForward)) leftSwipe.direction = .left webViewBox.addGestureRecognizer(leftSwipe) let rightSwipe = UISwipeGestureRecognizer(target: webViewBox, action: #selector(webViewBox.goBack)) leftSwipe.direction = .right webViewBox.addGestureRecognizer(rightSwipe) 

Your final result should look like this: 您的最终结果应如下所示:

    import UIKit
    import WebKit

    class ViewController: UIViewController {


@IBOutlet weak var webViewBox: WKWebView!

override func viewDidLoad() {
    super.viewDidLoad()


    //URL request:
    let urlReq = URLRequest(url: URL(string: "https://www.google.co.in")!)
    //Load the URL:        
    webViewBox.load(urlReq)



    //To go forward:
    let leftSwipe = UISwipeGestureRecognizer(target: webViewBox, action: #selector(webViewBox.goForward))
    leftSwipe.direction = .left
    webViewBox.addGestureRecognizer(leftSwipe)

    //To go back:
    let rightSwipe = UISwipeGestureRecognizer(target: webViewBox, action: #selector(webViewBox.goBack))
    rightSwipe.direction = .right
    webViewBox.addGestureRecognizer(rightSwipe)
  }
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM