来自资产的 Android WebView JavaScript

Posted

技术标签:

【中文标题】来自资产的 Android WebView JavaScript【英文标题】:Android WebView JavaScript from assets 【发布时间】:2012-03-13 22:23:19 【问题描述】:

如何使远程 html 页面上的 javascript 和图像从资产文件夹(或任何本地资源)加载?

【问题讨论】:

【参考方案1】:

回答: 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 和其他本地资源,然后加载远程内容。

【讨论】:

如果使用loadDataWithBaseURL 设置基本路径,为什么必须提供绝对路径?此外,这似乎在 4.1+ 中中断。 :( 这对我来说似乎适用于 4.1+,并且是迄今为止我能够使用未硬编码到资产文件夹中的 javascript 加载 HTML 的唯一方法。 如果 html 已经是远程的,无法编辑程序应该识别这些文件并替换 String html 中的字符串 在这个方案中,如果网页包含图片,则不会加载任何图片。 我们如何在 postURL 方法上实现这个【参考方案2】:

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

【讨论】:

能否请您详细告诉我如何在将html作为字符串后动态添加(file://)路径到.js。

以上是关于来自资产的 Android WebView JavaScript的主要内容,如果未能解决你的问题,请参考以下文章

从 Android 动态功能模块将资产加载到 WebView

使用本地资产/HTML/资源时,jQuery getScript 在 Android WebView 中不起作用

Android webview,在资产文件夹中加载javascript文件

Android SDK Webview加载不在资产文件夹中的本地文件

在应用程序中打开资产文件 pdf

了解Android的webview addjavascriptinterface