来自资产的Android WebView JavaScript

问题描述 投票:24回答:2

如何在资源文件夹(或任何本地资源)中加载远程HTML页面上的JavaScript和图像?

javascript android local assets
2个回答
42
投票

回答: 1.您必须将HTML加载到字符串中:

private String readHtml(String remoteUrl) {
    String out = "";
    BufferedReader in = null;
    try {
        URL url = new URL(remoteUrl);
        in = new BufferedReader(new InputStreamReader(url.openStream()));
        String str;
        while ((str = in.readLine()) != null) {
            out += str;
        }
    } catch (MalformedURLException e) { 
    } catch (IOException e) { 
    } finally {
        if (in != null) {
            try {
                in.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
    return out;
}

2.使用基本URL加载WebView:

String html = readHtml("http://mydomain.com/my.html");
mWebView.loadDataWithBaseURL("file:///android_asset/", html, "text/html", "utf-8", "");

在这种特殊情况下,您应该将要在页面上使用的所有.js文件驻留在项目的“assets”文件夹下的某个位置。例如:

/MyProject/assets/jquery.min.js

3.在远程html页面中,您必须加载驻留在应用程序中的.js和.css文件,如:

<script src="file:///android_asset/jquery.min.js" type="text/javascript"></script>

这同样适用于所有其他本地资源,如图像等,其路径必须从头开始

file:///android_asset/

WebView首先加载您提供的原始HTML作为字符串,然后选择.js,.css和其他本地资源,然后加载远程内容。


2
投票

如果动态创建HTML然后使用loadDataWithBaseURL,请确保任何本地资源,例如您的资源文件夹中的javascript在HTML中称为file:///(我花了很多时间来处理这个问题)

© www.soinside.com 2019 - 2024. All rights reserved.