Android webview - JavaScript 回调不起作用?

Android webview - JavaScript callback not working?

我正在使用 WebView 在 android 应用程序上显示网页。 https://developer.android.com/guide/webapps/webview.html

单击 HTML 中的按钮后,我可以成功到达 Android class WebAppInterface(来自示例)和显示 "Toast" 警报,但尝试回调到我的网页中定义的 javacsript 函数无效。

这是网页的代码:(Android.html)

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

<script type="text/javascript">
    function showAndroidToast(toast) {
        if (typeof Android != 'undefined') 
            Android.showToast(toast);       


    }

    function ChangeColor()
    {
        document.body.style.background = 'pink';
    }
</script>

这是Android应用的MainActivity的代码。它加载 url 并显示它。

public class MainActivity extends AppCompatActivity {

    WebView m_Webview;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        m_Webview = (WebView) findViewById(R.id.webview);

        WebSettings webSettings = m_Webview.getSettings();
        webSettings.setJavaScriptEnabled(true);
        webSettings.setDomStorageEnabled(true);
        m_Webview.setWebViewClient(new WebViewClient());
        m_Webview.loadUrl("android.html");


        WebView webView = (WebView) findViewById(R.id.webview);
        webView.addJavascriptInterface(new WebAppInterface(this,webView), "Android");
    }
}

这是 Android 应用程序上的 WebAppInterface:

public class WebAppInterface {

    Context mContext;
    WebView mView;

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

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

JavaScript 函数 ChangeColor 在 toast 显示后未被调用。

有关更多参考,请参阅:

谢谢!

解决方案是像这样使用 "post" 函数:

public void showToast(String toast) {
        Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
      //  WebView Web = new WebView(mContext);
       // mView.getSettings().setUserAgentString("Android WebView");
        mView.post(new Runnable() {
            public void run() {
                mView.loadUrl("javascript:ChangeColor()");
            }
        });
    }

同样在 KitKat 和 forward 上你需要使用 evaluateJavascript:

mView.evaluateJavascript("ChangeColor();",null);