Android禁止WebView返回时刷新
【摘要】 webview.goback()时会重新刷新页面,那么就不能看到返回上一页后,还保持之前的状态。 解决办法:就是每个跳转的页面都用一个新的webview来承载,如此一来,如果跳转越深入,就会形成页面视图的堆叠。返回时只需要将最上层的视图去掉即可。webview会消耗很多资源,不建议在一些跳转深度太大的情况下使用。那个应该考虑使用cookie来解决。还有我目前所遇到的这个...
webview.goback()时会重新刷新页面,那么就不能看到返回上一页后,还保持之前的状态。
解决办法:就是每个跳转的页面都用一个新的webview来承载,如此一来,如果跳转越深入,就会形成页面视图的堆叠。返回时只需要将最上层的视图去掉即可。webview会消耗很多资源,不建议在一些跳转深度太大的情况下使用。那个应该考虑使用cookie来解决。还有我目前所遇到的这个项目只会跳一到两层。
实现如下:
(1)在布局里添加一个容器
<FrameLayout android:id="@+id/framelayout_main" android:layout_width="match_parent" android:layout_height="match_parent"/>
- 1
- 2
- 3
- 4
- 5
(2)用java动态生成WebView,并且添加进去容器里,以下给出代码的核心部分,完整代码请到GitHub上下载。
public class MainActivity extends AppCompatActivity { private FrameLayout contentContainer; // 容器 private List<String> urlList = new ArrayList<>(); // 记录访问的URL @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); contentContainer = findViewById(R.id.framelayout_main); addWeb("http://www.baidu.com"); }
/** * 添加webview * * @param url */ private void addWeb(String url) { // 重点在这里,每次都新的URL都会创建一个WebView实例,添加到容器中 WebView mWeb = new WebView(MainActivity.this); WebSettings webSettings = mWeb.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setDomStorageEnabled(true); mWeb.setWebChromeClient(new WebChromeClient()); mWeb.setWebViewClient(new WebViewClient(){ @Override public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {// 截获跳转 String url = request.getUrl().toString(); if (!urlList.contains(url)) { addWeb(url); urlList.add(url); return true; } else { return super.shouldOverrideUrlLoading(view, request); } } }); mWeb.loadUrl(url); contentContainer.addView(mWeb); FrameLayout.LayoutParams params = new FrameLayout.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT ); mWeb.setLayoutParams(params); } // 返回处理时移除容器的最顶的视图(即当前页面视图) @Override public void onBackPressed() { // 点击返回按钮事件 int childCount = contentContainer.getChildCount(); if (childCount > 1) { contentContainer.removeViewAt(childCount - 1); urlList.remove(urlList.size() - 1); } else { super.onBackPressed(); } }
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
谢谢阅读。
文章来源: blog.csdn.net,作者:WongKyunban,版权归原作者所有,如需转载,请联系作者。
原文链接:blog.csdn.net/weixin_40763897/article/details/90607174
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)