Android:如何使用javascript界面​​显示吐司?

时间:2013-03-24 18:13:16

标签: javascript android webview

我想在网页视图中显示的网页上显示吐司,例如Google的例子:http://developer.android.com/guide/webapps/webview.html

我为这个名字创建了一个类:WebAppInterface.java

package com.test.test;

import android.annotation.TargetApi;
import android.app.ActionBar;
import android.os.Bundle;
import android.content.Context;
import android.os.Build;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.NavUtils;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.TextView;
import android.graphics.drawable.Drawable;
import android.graphics.drawable.GradientDrawable;
import android.graphics.Color;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.webkit.WebSettings;
import android.webkit.WebChromeClient;
import android.webkit.JavascriptInterface;
import android.app.Activity;
import android.view.KeyEvent;
import android.app.ProgressDialog;
import android.view.Window;
import android.widget.Toast;
import com.test.test.R;

public class WebAppInterface extends Activity{
    Context mContext;

    /** Instantiate the interface and set the context */
    WebAppInterface(Context c) {
        mContext = c;
    }

    /** Show a toast from the web page */
    @JavascriptInterface
    public void showToast(String toast) {
        Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
    }
}

这是我的主要活动代码MainActivity.java

class JsObject {
    @JavascriptInterface
    public String toString() { return "injectedObject"; }
 }
myWebView.addJavascriptInterface(new JsObject(), "injectedObject");

Web视图加载的页面包含以下代码:

<input type="button" value="Say hello" onClick="showAndroidToast('Hello Android!')" />

<script type="text/javascript">
    function showAndroidToast(toast) {
        Android.showToast(toast);
    }
</script>

我完全按照谷歌的例子说明,但是它起作用了......为什么?

谢谢!

1 个答案:

答案 0 :(得分:4)

使用

myWebView.addJavascriptInterface(new JsObject(), "Android");

在javascript中,变量Android将可用。您在注册Javascript界面​​时使用的是injectedObject

http://developer.android.com/guide/webapps/webview.html