只要将网页中的连接,比如
[html] view plain copy
- <a href=“http://xxx.com.cn”/>
直接替换为
[html] view plain copy
- <a href=“http:///xxx.com.cn/index.html”/>
即可解决该问题.
二.页面中的重定向是必须的,那么我们就需要自己维护一个webview的历史栈,根据自己的需求进行过滤跳转或者重新加载页面:
判断到当前为重定向后的链接,那么那么当回退的时候就需要忽略上一级的链接,不使用webview.goback(),移除重定向和重定向后的url,
获取到初始页面链接后自己进行loadUrl()操作.
3.还有一种方法,和方法2类似,需要自己维护webview的历史栈,但是需要前端的配合,提供js函数获取网页是否进行重定向
在webviewClient回调shouldoverloading()中过滤url时,若属于重定向的地址,则不加入栈中,回退时根据历史栈加载即可.
这里主要讲一下方法二:
首先定义一个历史栈 :
[html] view plain copy
- private ArrayList<String> loadHistoryUrls = new ArrayList<String>();
把初始页面Url加入
[html] view plain copy
- loadHistoryUrls.add(INITAL_WEB_URL);
然后加入加载的url:
[java] view plain copy
-
public boolean shouldOverrideUrlLoading(WebView view,String url){
-
//将过滤到的url加入历史栈中
-
loadHistoryUrls.add(url);
-
return true;
-
}
最后在webview.goback()处理:
[java] view plain copy
-
@Override
-
public boolean onKeyDown(int keyCode, KeyEvent event) {
-
//判断是否可以返回操作
-
if (webView.canGoBack() && event.getKeyCode() == KeyEvent.KEYCODE_BACK) {
-
//过滤是否为重定向后的链接
-
if(loadHistoryUrls.size()>0&&loadUrls.get(loadHistoryUrls.size()-1).contains(“index.html”))
-
//移除加载栈中的最后两个链接
-
loadHistoryUrls.remove(loadHistoryUrls.get(loadHistoryUrls.size()-1));
-
loadHistoryUrls.remove(loadHistoryUrls.get(loadHistoryUrls.size()-1));
-
//加载重定向之前的页
-
webview.load(loadUrls.get(loadHistoryUrls.size()-1));
-
return true;
-
}
-
}
-
}
bview.load(loadUrls.get(loadHistoryUrls.size()-1));
-
return true;
-
}
-
}
-
}