Android 与 JavaScript 互调

做混合开发的同学,肯定了解 Android 与JS互调,本文只是Android 与 JavaScript 互调的简单使用,大神请忽略。

阅读完本文,你应该可以学会,如何通过Android调用JS方法,JS调用Android的方法。

Android代码

@SuppressLint("SetJavaScriptEnabled")
public class MainActivity extends Activity {

	//声明一个webview
	private WebView mWebView;
	
	private MyWebViewClient WVClient;

	private WebSettings webSettings;
	
	private MyWebChromeClient chromeClient;
	

	//调用JS的Button
	private Button callJSBtn;
	
	//Object对象,用来跟JS网页绑定
	private JSObject  jsobject;
	
	//android调用JS网页的时候会用到
	private Handler mHandler = new Handler();
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		initView();
	}

	private void initView() {
		// TODO Auto-generated method stub
		mWebView = (WebView) findViewById(R.id.webview);
		callJSBtn = (Button)findViewById(R.id.calljs);
		
		WVClient = new MyWebViewClient();
		chromeClient = new MyWebChromeClient();
		jsobject = new JSObject(MainActivity.this); 
		
		webSettings = mWebView.getSettings();
		webSettings.setJavaScriptEnabled(true);
		webSettings.setBuiltInZoomControls(true);
		webSettings.setSavePassword(false);
		
		//支持多种分辨率,需要js网页支持
		webSettings.setUserAgentString("mac os");
		webSettings.setDefaultTextEncodingName("utf-8");
		
		//显示本地js网页
		mWebView.loadUrl(StringUrl.LOACL);
		
		
		mWebView.setWebViewClient(WVClient);
		mWebView.setWebChromeClient(chromeClient);
		
		//注意第二个参数JsTest,这个是JS网页调用Android方法的一个类似ID的东西
		mWebView.addJavascriptInterface(jsobject, "jsTest");
		
		
		//调用JS网页
		callJSBtn.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View v) {
				mHandler.post(new Runnable() {
					
					@Override
					public void run() {
						//调用JS中的 函数,当然也可以不传参
						mWebView.loadUrl("javascript:androidCallJS('顺便传个参数给JS!')");
					}
				});
			}
		});
		
	}

	
	//单击系统返回键网页回退
	@Override
	public void onBackPressed() {
			if (mWebView.canGoBack()) {
				mWebView.goBack();
			}
		 else {
			this.finish();
		}
	}

}


html代码 放在 assets目录下。

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html40/strict.dtd">
<HTML>
<HEAD>
<meta name="viewport" content="width=device-width, target-densitydpi=device-dpi" />
<META http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script>
   function androidCallJS(name){
      alert("android call me!"+name);
   }
   
    function testJsCallAndroid(){
      jsTest.JsCallAndroid();
      }
   
</script>
</HEAD>
<BODY>
<span>测试js使用</span>

<button id='btntest' οnclick='testJsCallAndroid()'>JS调用android的方法</button>
</BODY>
</HTML>




  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值