使用android WebView加载现有的.html文件

lap*_*aph 85 android android-assets android-webview

我确实尝试过使用Google代码和其他资源的示例,演示WebView,但是当我尝试在我自己的代码中执行此操作时,它对我不起作用.

我想加载myfile.html我放在assets文件夹中,并使用:

private WebView myWebView;

myWebView.loadUrl("file:///android_assets/myfile.html");
Run Code Online (Sandbox Code Playgroud)

在模拟器上显示错误

file:///android_assets/myfile.html无法加载网页:找不到请求的文件. /android_assets/myfile.html

当我把该文件放到文件res/raw/夹并使用:

myWebView.loadUrl("file:///android_res/raw/myfile.html");
Run Code Online (Sandbox Code Playgroud)

然后只有模拟器android 2.2 API级别8可能加载文件,其他旧版本显示相同的错误.我错过了什么吗?

有没有办法在适用于所有API版本的应用程序包中加载现有的.html文件?

lap*_*aph 155

好吧,那是我非常愚蠢的错误.我在这里发布答案,以防有人遇到同样的问题.

存储在assets文件夹中的文件的正确路径是file:///android_asset/*(资产文件夹没有"s",我一直认为它必须有"s").

并且,mWebView.loadUrl("file:///android_asset/myfile.html");适用于所有API级别.

我仍然不知道为什么mWebView.loadUrl("file:///android_res/raw/myfile.html");只能在API级别8上工作.但现在没关系.

  • FWIW我认为这不是一个愚蠢的错误.我现在犯了同样的错误,两次.这不直观!首先创建一个名为"assets"的文件夹,然后通过"android_asset"(没有"s")来引用它?这是愚蠢的平台,IMO:P (50认同)
  • 糟糕的`原始'不起作用.我会用'raw-de`,`raw-fr`等等.现在我必须自己做. (3认同)
  • 嗨Aditya,我相信错误是因为你的文件是.xml.loadUrl假设加载.html文件.如果我错了,请纠正我. (2认同)

小智 17

将.html文件粘贴到项目文件夹的assets文件夹中.在layout文件夹中创建一个xml文件,其中包含以下代码:my.xml:

<WebView  xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/webview"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
    />
Run Code Online (Sandbox Code Playgroud)

在活动中添加fol代码

setContentView(R.layout.my);
    WebView mWebView = null;
    mWebView = (WebView) findViewById(R.id.webview);
    mWebView.getSettings().setJavaScriptEnabled(true);
    mWebView.loadUrl("file:///android_asset/new.html"); //new.html is html file name.
Run Code Online (Sandbox Code Playgroud)


Epi*_*rce 13

如果你的结构应该是这样的:

/assets/html/index.html

/assets/scripts/index.js

/assets/css/index.css

然后就做(Android WebView:处理方向更改)

    if(WebViewStateHolder.INSTANCE.getBundle() == null) { //this works only on single instance of webview, use a map with TAG if you need more
        webView.loadUrl("file:///android_asset/html/index.html");
    } else {
        webView.restoreState(WebViewStateHolder.INSTANCE.getBundle());
    }
Run Code Online (Sandbox Code Playgroud)

确保添加

    WebSettings webSettings = webView.getSettings();
    webSettings.setJavaScriptEnabled(true);
    webSettings.setJavaScriptCanOpenWindowsAutomatically(true);
    if(android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.JELLY_BEAN) {
        webSettings.setAllowFileAccessFromFileURLs(true);
        webSettings.setAllowUniversalAccessFromFileURLs(true);
    }
Run Code Online (Sandbox Code Playgroud)

然后只使用网址

<html>
<head>
    <meta charset="utf-8">
    <title>Zzzz</title>
    <script src="../scripts/index.js"></script>
    <link rel="stylesheet" type="text/css" href="../css/index.css">
Run Code Online (Sandbox Code Playgroud)


小智 6

将.html文件复制并粘贴到项目的assets文件夹中,并在onCreate()的Activity中添加以下代码.

        WebView view = new WebView(this);
        view.getSettings().setJavaScriptEnabled(true);
        view.loadUrl("file:///android_asset/**YOUR FILE NAME**.html");
        view.setBackgroundColor(Color.TRANSPARENT);
        setContentView(view);
Run Code Online (Sandbox Code Playgroud)