Android webview不会从脚本src执行javascript

时间:2013-08-22 22:46:56

标签: javascript android android-webview adk

问题

webview实际上并不执行从远程位置通过src加载的脚本

选中并仔细检查

  • 权限:<uses-permission android:name="android.permission.INTERNET" />

  • 文件http://localhost/android/test.js存在

  • 在加载网址之前调用view.getSettings().setJavaScriptEnabled(true);

代码

给定WebView viewContext context

构建文档

它需要cookie,因此需要动态构建它。 file:// urls不允许使用cookie。无论哪种方式,这'应该'正常工作。

String html =
        "<html>\n" +
        "<head>\n" +
        "</head>\n" +
        "<body>\n" +
        "<script src=\"http://localhost/android/test.js\"  type=\"text/javascript\"></script>\n" +
        "</body>\n" +
        "</html>";
String mime = "text/html";
String encoding = "utf-8";

启用Cookie

简单的功能,以确保设备保留cookie。

CookieSyncManager.createInstance(context);
CookieSyncManager.getInstance().sync();

创建用于记录的chrome客户端

记录所有消息[两次],当页面完成后,加载执行一个功能。这实际上运作良好。添加更多[远程]脚本标记会延迟执行。

WebChromeClient client = new WebChromeClient ( ) {
        @Override
        public boolean onConsoleMessage(ConsoleMessage consoleMessage) {
            Log.e( "JSINTERFACE", consoleMessage.message() );
            return super.onConsoleMessage(consoleMessage);
        }

        @Override
        public void onProgressChanged(WebView view, int newProgress) {
            super.onProgressChanged(view, newProgress);
            loadingFinished = ( newProgress == 100 );
            Log.d( "JSINTERFACE", "Progress is:" + newProgress );
            if ( loadingFinished ) {
                Log.i( "JSINTERFACE", "Finished loading webclient" );
                execute();
            }
        }

    };

加载视图

附加chrome客户端,启用javascript,添加界面并开始加载!

view.setWebChromeClient( client );
view.getSettings().setJavaScriptEnabled(true);
view.addJavascriptInterface( new JSInterface(), "bridge" );
view.loadDataWithBaseURL( "http://localhost/android/", html, mime, encoding, null );

界面

界面如下

public class JSInterface{

    @JavascriptInterface
    public void result( int success, String message ) {
        Log.i( "JSINTERFACE", message );
        // TODO handler
    }
}

我实际上可以通过调用

来测试javascript和界面
view.loadUrl("javascript:bridge.result( 0, 'TESTING INTERFACE' );");

只要这个推迟到加载完成后(例如在execute function中就可以正常工作。并且会记录该消息。

test.js脚本

一个非常简单的脚本

console.log( 'test loaded' );
var test = function() { console.log( 'test' ); bridge.result( 1, 'res' ); }

为什么不起作用?

  • 我没有看到test loaded日志,应该被客户端捕获

  • 当我致电view.loadUrl("javascript:console.log(test)时,我得到test is not defined

0 个答案:

没有答案