Wkwebview неправильно отображает в iOS 10

У меня есть WKWebView внутри UITableViewCell. Запрос загрузки веб-представления, а затем после завершения загрузки я изменю высоту веб-представления, чтобы она была равна его высоте содержимого, а затем отрегулирую высоту ячейки табличного представления соответствующим образом.

произошло то, что веб-представление отображает только область, которая соответствует размеру экрана. Когда я прокручиваю вниз, все белое. Но я вижу, что веб-представление, отображаемое с правильной высотой, нажмите и удерживайте белую область на веб - представлении выбор. Масштабирование с помощью pinch делает область веб-просмотра, отображаемую на экране, видимой, но другие области иногда становятся белыми.

Он отлично работает на iOS 8 и 9. Я создал пример проекта, чтобы продемонстрировать это поведение здесь: https://github.com/pawin/strange-wkwebview

Открыть Радар: https://openradar.appspot.com/radar?id=4944718286815232

обновление: эта проблема решена в iOS11

5 ответов


вам нужно заставить WKWebView макет пока ваш UITableView свитки.

// in the UITableViewDelegate
func scrollViewDidScroll(scrollView: UIScrollView) {
    if let tableView = scrollView as? UITableView {
        for cell in tableView.visibleCells {
            guard let cell = cell as? MyCustomCellClass else { continue }
            cell.webView?.setNeedsLayout()
        }
    }
}

    func reloadWKWebViewIfNeeded() {
    for cell in self.tableView.visibleCells {
        guard let webviewCell = cell as? WebviewCell else { continue }

        // guard cell height > screen height

        webviewCell.webview.reload()
    }
}

override func scrollViewDidEndDragging(scrollView: UIScrollView, willDecelerate decelerate: Bool) {
    guard !decelerate else { return }

    self.reloadWKWebViewIfNeeded()
}

override func scrollViewDidEndDecelerating(scrollView: UIScrollView) {
    self.reloadWKWebViewIfNeeded()
}

Не лучшее решение, но, по крайней мере, пользователь может видеть остальную часть контента


у меня такая же проблема-добавьте WKWebView в UITableViewCell, и я решил эту проблему следующими шагами:

1.Создайте экземпляр UITextView и добавьте его в superview UITableView(UIViewControllew.вид) 2.реализовать коды в scrollViewDidScroll такой:
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    [self.xxtextView becomeFirstResponder];
    [self.xxtextView resignFirstResponder];
}

эти коды могут вызвать увеличение производительности процессора, вы можете исправить это каким-то образом, например, мы используем переменную temp в качестве порогового значения.

Я не думаю, что это идеальное решение метод, но он работает для меня.


В конце концов я понял, что textview becomeFirstResponder просто снова привел макет webview, поэтому вы можете просто исправить это следующим образом:

CGFloat tempOffset = 0;

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    if (!tempOffset || ABS(scrollView.contentOffset.y - tempOffset) > ScreenHeight/2)
    {
        [self.wkWebView setNeedsLayout];
        tempOffset = scrollView.contentOffset.y;
    }
}

в objective-C вот как я решаю проблему.

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    NSArray * visibleCell = [self.tableView visibleCells];

    for (CustomUITableViewCell * cell in visibleCell) {
        if ([cell isKindOfClass:[CustomUITableViewCell class]]) {
            [cell.wkWebView setNeedsLayout];
        }
    }
}

этот код соберет всю видимую ячейку и сделает setNeedsLayout в быстром перечислении во время прокрутки пользователя.


Im также имеет uitableview с ячейкой с wkWebView. И я стек с той же проблемой. Но своевременно вы можете исправить это с помощью этого кода. По производительности не беспокойтесь. Я тестировал это решение на iphone 5s, и оно было принято 10-15% CPU только при прокрутке uitableView с видимой веб-ячейкой.

func scrollViewDidScroll(_ scrollView: UIScrollView) {
   //TODO: Remove this fix when WKWebView will fixed
   if let cell = tableView.cellForRow(at: IndexPath(row: 1, section: 0)) as? WKWebViewCell {
      // Here we take our cell
      cell.wkWebView?.setNeedsLayout() 
      // here is "magic" (where wkWebView it is WKWebView, which was 
      // previously added on cell)
   }
}