google 已经不建议使用NestedScrollView 嵌套Webview 来使用了,但是实际上,很多小伙伴还是遇到各种奇葩的需求和产品,迫不得已还是会这样嵌套,但是肯定会遇到很多情况,接和我的实际,以及遇到的情况,我总结一下几点和解决方法,方便记忆也给大家提供一个思路:
1.ANR 问题
很有可能在页面更加载完毕就会出来“程序无响应”的ANR提示,然后就是黑屏,这个时候一定不要着急不要慌,可以debug看程序走的步骤,如果程序进行中遇到了Exception,也是会导致ANR的,把异常解决了就可以,如果debug没有发现问题,那么就需要看ANR日志了,至于收集方法,可以看我往期博客,具体命令是 adb bugreport
2.webview内容点击切换时,NestdScorllview 上下滑动页面
这个问题,困扰了我一上午,百度出来的都是要重写webview,但是也没有用,后来我发现,锁定父布局的焦点可以解决这个事情,但是,仅仅锁定一层还不行,还需要在根布局上也锁定,这样才能解决页面上下滑动的问题
<com.xuexiang.xui.widget.XUIObservableScrollView
android:id="@+id/nestedView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white_f0f1f5"
android:orientation="vertical"
android:overScrollMode="never"
android:scrollbars="none"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintTop_toBottomOf="@+id/pointsRecode">
<LinearLayout
android:layout_width="match_parent"
android:descendantFocusability="blocksDescendants"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginLeft="@dimen/dp_8"
android:layout_marginTop="@dimen/dp_10"
android:elevation="3dp"
android:translationZ="@dimen/dp_3"
android:layout_marginRight="@dimen/dp_8"
android:background="@drawable/layout_shape_white"
android:padding="@dimen/dp_5">
<WebView
android:id="@+id/mWebView"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
</LinearLayout>
</com.xuexiang.xui.widget.XUIObservableScrollView>
最重要的就是android:descendantFocusability="blocksDescendants" 这句话了
3.webview底部留白的问题
当你解决完上面两个问题后,很可能发现webview的底部布局正常页面下面还多出来一块空白页面,说不要紧吧,肯定影响页面美观,所以还是要解决的。
mWebView.webViewClient = object : WebViewClient() {
//加载完成的时候会回调
override fun onPageFinished(webView: WebView, s: String) {
val params = mWebView.layoutParams
params.width = resources.displayMetrics.widthPixels.minus(SizeUtils.dp2px(30f))
params.height = mWebView.height - nestedView.height
mWebView.layoutParams = params
}
}
动态获取webview的高度重新设置,就可以解决这个问题,另外在网页内容切换,有改变内容视图高度的时候,也要主动去重新设置webview的高度,这样才可以解决底部空白的问题。
今天先这样,快放假了,在坚持一下
网友评论