我有一个表格视图单元格,布局是这样的-
ContentView
- StackView
- Fixed Height UILabel
- UIView (Webview Container)
- Fixed Height UILabel
- ... more views
现在,我尝试在这个UIView中添加一个webview,如下所示-
func prepareQuestionWebView() {
let webConfiguration = WKWebViewConfiguration()
let contentController = WKUserContentController();
webConfiguration.userContentController = contentController
webView = WKWebView(frame: CGRect(origin: CGPoint.zero, size: questionView.frame.size))
webView?.scrollView.isScrollEnabled = false
webView?.scrollView.bounces = false
webView?.scrollView.bouncesZoom = false
webView?.autoresizingMask = [.flexibleWidth, .flexibleHeight]
webView?.translatesAutoresizingMaskIntoConstraints = false
webView?.tag = -1
webView?.navigationDelegate = self
questionView.removeAllSubviews()
questionView.addSubview(webView!)
webView?.contentScaleFactor = 1
}
我为我的堆栈视图和webview容器创建了以下插座-
@IBOutlet weak var questionView: UIView!
@IBOutlet weak var rootStack: UIStackView!
为了使questionView帧大小与webview的内容大小相等,我这样做-
func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
if webView.isLoading == false {
DispatchQueue.main.asyncAfter(deadline: .now() + 1.0) {
webView.evaluateJavaScript("document.body.scrollHeight", completionHandler: { (result, error) in
if let height = result as? CGFloat {
self.setHeightData(height, webView)
}
})
}
}
}
func setHeightData(_ height: CGFloat, _ wv: WKWebView) {
switch wv.tag {
case -1:
questionView.frame = CGRect.init(x: 0, y: 36, width: rootStack.frame.width, height: height)
default:
break
}
wv.layoutSubviews()
questionView.layoutIfNeeded()
rootStack.layoutSubviews()
rootStack.layoutIfNeeded()
}
这会更新webview的大小及其容器的大小,但由于某种原因,堆栈视图中webview容器之后的元素不会更新,因此它们与webview容器重叠
那么,在我设置questionView的高度等于其webview的内容之后,我如何更新stackview视图呢?
或者,有没有其他方法可以使questionView (webview容器)的高度根据其内容动态变化,并在其高度发生变化时使其余视图向下移动?
转载请注明出处:http://www.jxbyjx.net/article/20230521/1188249.html