1.android中利用webview调用网页上的js代码。 Android 中可以通过webview来实现和js的交互,在程序中调用js代码,只需要将webview控件的支持js的属性设置为true,,然后通过loadUrl就可以直接进行调用,如下所示: mWebView.getSettings().setJavaScriptEnabled(true); mWebView.loadUrl("javascript:test()"); 2. 网页上调用android中java代码的方法 在网页中调用java代码,需要在webview控件中添加javascriptInterface。如下所示: mWebView.addJavascriptInterface(new Object() { public void clickOnAndroid() { mHandler.post(new Runnable() { public void run() { Toast.makeText(Test.this, "测试调用java", Toast.LENGTH_LONG).show(); } }); } }, "demo"); 在网页中,只需要像调用js方法一样,进行调用就可以
android如何调用主机上的js代码,android中利用webview调用网页上的js代码和注意事项...
最新推荐文章于 2021-11-26 11:18:47 发布
本文详细介绍了在Android中如何使用WebView与JavaScript进行交互,包括Android调用JS代码和网页调用Android Java方法,并提供了具体的代码示例。同时,提到了在Android 2.3.1版本中可能遇到的问题及解决办法,强调了使用JavaScriptInterface的安全注意事项。
摘要由CSDN通过智能技术生成
b.c
3. Java代码调用js并传参 首先需要带参数的js函数,如function test(str),然后只需在调用js时传入参数即可,如下所示: mWebView.loadUrl("javascript:test('aa')"); 4.Js中调用java函数并传参 首先一样需要带参数的函数形式,但需注意此处的参数需要final类型,即得到以后不可修改,如果需要修改其中的值,可以先设置中间变量,然后进行修改。如下所示: mWebView.addJavascriptInterface(new Object() { public void clickOnAndroid(final int i) { mHandler.post(new Runnable() { public void run() { int j = i; j++; Toast.makeText(Test.this, "测试调用java" + String.valueOf(j), Toast.LENGTH_LONG).show(); } }); } }, "demo"); 然后在html页面中,利用如下代码
b.c
, 即可实现调用 注意事项: (android webview js与android互动注意事项) 用2.3.1开发会出 ERROR/InputDispatcher(61): channel '40723150 com.JavaScriptCom/com.JavaScriptCom.JavaScriptCom (server)' ~ Channel is unrecoverably broken and will be disposed! 这个错误,必须用2.1的模拟器,这个估计是BUG. 附代码: AndroidManifest.xml <?xml version="1.0" encoding="utf-8"?> JavaScriptCom.java package com.JavaScriptCom; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.view.View; import android.view.View.OnClickListener; import android.webkit.WebSettings; import android.webkit.WebView; import android.widget.Button; import android.widget.EditText; import android.widget.TextView; public class JavaScriptCom extends Activity { final class runJavaScript { public void runOnAndroidJavaScript(final String str) { h.post(new Runnable() { // @Override public void run() { TextView show = (TextView) findViewById(R.id.show); show.setText("This is a message from javascript:" + str); } }); } } private EditText txt; private WebView wv; private Button btn; private Handler h = new Handler(); /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); setContentView(R.layout.main); txt = (EditText) findViewById(R.id.txt); wv = (WebView) findViewById(R.id.wv); btn = (Button) findViewById(R.id.btn); WebSettings webSettings = wv.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setSaveFormData(false); webSettings.setSavePassword(false); webSettings.setSupportZoom(false); wv.addJavascriptInterface(new runJavaScript(), "myjs"); String url = "file:///android_asset/android.html"; wv.loadUrl(url); btn.setOnClickListener(new OnClickListener() { public void onClick(View arg0) { // TODO Auto-generated method stub wv.loadUrl("javascript:get4Android('" + txt.getText().toString() + "')"); } }); } } android.html <?xml version="1.0" encoding="utf-8"?>