我在屏幕底部有一个嵌入式webView,它会加载Facebook评论javascript插件。
我希望将此webView无缝集成到屏幕中,而不必强迫用户滚动其内容。
但是,当用户点击某些webView按钮时,UI高度会发生变化,从而使webView可滚动。
如何根据动态内容动态更新webView高度约束?
答案 0 :(得分:6)
是的,你可以这样做。在storyboard中为您的Web视图设置高度约束,然后在webviewDidFinishLoad中执行以下操作
webView.scrollView.scrollEnabled=false;
heightConstraint.constant = webView.scrollView.contentSize.height
其中heightConstraint
是网络视图的高度约束的IBOutlet。如果需要,在修改约束后调用setNeedsLayout()。还要确保将Web视图的底部约束设置为等于滚动视图的底部,以便它可以自由扩展。
<强>更新强> 您可以为webview的滚动视图添加contentSize的键值观察器。你可以这样做
var myContext = 0
webView.scrollView.addObserver(self, forKeyPath: "contentSize", options: .New, context: &myContext)
override func observeValueForKeyPath(keyPath: String?, ofObject object: AnyObject?, change: [String : AnyObject]?, context: UnsafeMutablePointer<Void>) {
if context == &myContext {
heightConstraint.constant = webView.scrollView.contentSize.height
//call layout update if needed
} else {
super.observeValueForKeyPath(keyPath, ofObject: object, change: change, context: context)
}
}