Android中Java與JavaScript之間交互
Android代碼:
package com.fyfeng.testjavascript; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.support.v7.app.ActionBarActivity; import android.util.Log; import android.webkit.WebView; import android.widget.Toast; public class MainActivity extends ActionBarActivity { private static final String tag = MainActivity.class.getSimpleName(); WebView webView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); webView = (WebView) this.findViewById(R.id.webview); webView.getSettings().setJavaScriptEnabled(true);//設置可以JavaScript webView.loadUrl("http://192.168.1.104:8080/examples/");//加載網頁 webView.addJavascriptInterface(new PayYa(), "pay");//定義一個支付結果,模擬。PayYa為支付接口處理類。 } public void onClickPay() { Intent intent = new Intent(this, SecondActivity.class);//模擬打開另外一個支付界面。 startActivityForResult(intent, 1000); } public void onPayCallback(String result) { Log.d(tag, "result = " + result); webView.loadUrl("javascript:payCallback('" + result + "');");//通知網頁支付結果。 } @Override public void onActivityResult(int requestCode, int resultCode, Intent data) {//支付結果返回 Log.d(tag, "requestCode = " + requestCode + ", resultCode = " + resultCode); switch (requestCode) { case 1000: { if (Activity.RESULT_OK == resultCode) { onPayCallback("hello, 這是支付結果. !"); } break; } } } public final class PayYa { @android.webkit.JavascriptInterface public void pay(String hello) {//支付請求處理函數 Log.d(tag, "pay = " + hello); onClickPay(); } public void show(String args) {//這個函數是為了輔助顯示網頁中的alert對話框。 Toast.makeText(getApplicationContext(), args, Toast.LENGTH_SHORT).show(); } } }
網頁部分代碼:
<!DOCTYPE HTML><html lang="en"><head> <meta charset="UTF-8"> <title>Apache Tomcat Examples</title> <script type="text/javascript"> function doPay(args){ javascript:pay.pay(args+(new Date()));//調用Android本地支付接口函數,參數為args+new Date(); pay為在Android原生應用代碼中定義的一個支付對象,這個支付對象有個pay(...)方法。 //javascript:pay.show("hello"); } function payCallback(args){//Android本地支付處理完畢回調該函數,并把支付結果傳遞到該函數。 //alert("pay callback = "+args); //打印支付結果。 javascript:pay.show(args); ////在Android的WebView中無法顯示Alert對話框,只能借助Android原生Toast或者Dialog來顯示。 } </script> </head> <body> <button onclick="doPay('hello')">doPay</button><!-- 點擊支付事件。 --> </body></html>
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!