WKWebView使用遇到的坑,WKWebView返回向上移,代理报错,返回页面报错

今天使用WKWebView的时候遇到了一些坑和大家分享一下。

WKWebView返回向上移(64点)

刚开始显示没有问题但是,执行了goback返回上一级之后数据上移了64左右的点。
解决方案:

    //这里的self是控制器
    [self setAutomaticallyAdjustsScrollViewInsets:NO];
    self.webView.y = 64;
    self.webView.height = self.view.height - 64;

使用代理什么都没有调用写报错

- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler{
    //下面这句话一定不能少一少就报错
    decisionHandler(WKNavigationActionPolicyAllow);
}


- (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(WKNavigationResponse *)navigationResponse decisionHandler:(void (^)(WKNavigationResponsePolicy))decisionHandler{
    //下面这句话一定不能少一少就报错
    decisionHandler(WKNavigationResponsePolicyAllow);
}

返回控制器的时候报错

没有移除监听者,一般我们用WKWebView都会用kvo监听事件。没有移除会报错。

[self.webView removeObserver:self forKeyPath:@"estimatedProgress"];
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 WKWebView 中实现侧滑返回功能,你可以按照以下步骤进行操作: 1. 首先,确保你的 WKWebView 处于导航栈中的顶层。这是因为侧滑返回通常与导航控制器 (UINavigationController) 关联。 2. 然后,获取 WKWebView 的 UIScrollView 对象。你可以通过遍历 WKWebView 的 subviews 属性找到它。例如,使用下面的代码: ```swift extension UIView { func findScrollView() -> UIScrollView? { if let scrollView = self as? UIScrollView { return scrollView } for subview in subviews { if let scrollView = subview.findScrollView() { return scrollView } } return nil } } // 在你的视图控制器中调用该方法来获取 WKWebView 的 UIScrollView 对象 if let scrollView = webView.findScrollView() { // 在这里进行后续操作 } ``` 3. 为 UIScrollView 添加一个 UIPanGestureRecognizer 手势识别器,并实现手势的处理方法。在手势处理方法中,你可以检测到用户的滑动手势并执行相应的操作。例如,你可以使用下面的代码: ```swift let swipeBackGesture = UIPanGestureRecognizer(target: self, action: #selector(handleSwipeBackGesture(_:))) scrollView.addGestureRecognizer(swipeBackGesture) @objc func handleSwipeBackGesture(_ gesture: UIPanGestureRecognizer) { let translation = gesture.translation(in: webView) let velocity = gesture.velocity(in: webView) switch gesture.state { case .began: if velocity.x > 0 && translation.x > 0 && scrollView.contentOffset.x <= 0 { // 在开始拖动时,检测到向右滑动的手势,并且 webView 的 contentOffset.x 小于等于 0 // 在这里执行你想要的操作,例如返回上一级页面 } case .changed: // 在拖动过程中,你可以根据需要执行一些操作 case .ended, .cancelled: // 手势结束或取消时,你可以根据需要执行一些操作 default: break } } ``` 在上述代码中,我们通过手势的位移和速度等信息来判断用户是否进行了向右滑动的操作。如果满足条件,你可以执行相应的操作,例如返回上一级页面。 希望以上信息对你有帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值