Android webview的解析



WebView为Android 加载网页的一个控件,

webview加载链接的方法为webview.loadUrl();

一.webview的打开 mWebView.setWebViewClient(new WebViewClient()); 此方法使网页在当前应用的内部打开,如果不设置网页会从浏览器打开。 二。获取网页的头部 获取网页头部的方法有两种 1.此方法获取的标题是网页加载完毕时的标题
mWebView.setWebViewClient(new WebViewClient() {

    //此方法会在网页加载完毕时调用
    @Override
    public void onPageFinished(WebView view, String url) {
        super.onPageFinished(view, url);
        //获取网页的头部标题
        String title = view.getTitle();
    }
    
}


2.此方法可以动态获取网页的标题,只要网页有标题就会显示,
能动态获取网页标题的改变,但是此方法有个缺陷如果两个网页公用一个webview,
如果从第二个链接返回到第一个链接的时候,
标题还停留在第二个网页的标题,不会刷新

 mWebView.setWebChromeClient(new WebChromeClient(){
    @Override
    public void onReceivedTitle(WebView view, String title) {
        super.onReceivedTitle(view, title);
         //此处的title为网页的标题
 }
});

三。js交互
1.原生调用h5的方法

mWebView.loadUrl("javascript:h5method()");

2.h5调用原生的方法
//开启与h5页面的交互
WebSettings settings = mWebView.getSettings();
settings.setJavaScriptEnabled(true);
//设置网页的加载模式是否缓存
settings.setCacheMode(WebSettings.LOAD_NO_CACHE);

//h5调用原生的方法
mWebView.addJavascriptInterface(new Js(this), "JsName");
public class Js {
    private Context context;

    public Js(Context context) {
        this.context = context;
    }

    @JavascriptInterface
    public void method() {
        //此处是和h5页面定义的方法,注意此处是处于子线程,如果想要更新ui需要利用handler开启一个主线程。
    }
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android WebView 中,AppCache(Application Cache)是一种用于离线应用的缓存机制,它允许网页应用在离线状态下加载和使用资源。AppCache 使用一个描述文件(通常是 `manifest.appcache`)来指定要缓存的文件列表。 当 WebView 加载包含 AppCache 的网页时,它会解析 manifest.appcache 文件,并按照其中指定的文件列表下载和缓存相关资源。manifest.appcache 文件是一个简单的文本文件,其内容由以下几个部分组成: 1. CACHE MANIFEST:指示这是一个 AppCache 文件。 2. CACHE:列出需要缓存的文件列表。每行表示一个文件的路径,可以是相对路径或绝对路径。这些文件将被下载并存储在本地缓存中。 3. NETWORK:列出不会被缓存的文件列表。这些文件将始终从网络加载。 4. FALLBACK:指定离线状态下的备用资源。当某个文件无法从缓存中加载时,会尝试从 FALLBACK 中指定的资源进行替代。 示例 manifest.appcache 文件内容如下: ``` CACHE MANIFEST # Version: 1.0.0 CACHE: index.html styles.css script.js NETWORK: api.example.com FALLBACK: offline.html /offline.html ``` 上述示例中,index.html、styles.css 和 script.js 会被缓存,api.example.com 不会被缓存(每次都从网络加载),而 offline.html 将作为离线状态下的替代资源。 需要注意的是,AppCache 在 Android 4.4(KitKat)之后被废弃,推荐使用 Service Worker 和其他离线技术来替代。因此,在开发新的应用时,建议考虑使用更现代的离线方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值