Android與Javascript互動樣本(二)

來源:互聯網
上載者:User

MainActivity如下:

package cn.testjavascript;import android.os.Bundle;import android.view.View;import android.view.View.OnClickListener;import android.webkit.WebView;import android.widget.Button;import android.app.Activity;/** * Demo描述: * JavaScript與Android中的方法 * 的相互調用 *  * 參考資料: * http://blog.csdn.net/wangtingshuai/article/details/8631835 */public class MainActivity extends Activity {   private WebView mWebView;   private Button mButton;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);init();}private void init(){//以下為Javascript調用Java--------------------------mWebView=(WebView) findViewById(R.id.webView);initWebViewSettings();//載入本地Html檔案mWebView.loadUrl("file:///android_asset/test.html");//注意://addJavascriptInterface方法中第二參數//它表示我們的java對象javaClass的別名.這樣js就可以通過該別名來調用Android中的方法//即js代碼中的://window.testjs.firstFunction//window.testjs.secondFunctionJavaClass javaClass=new JavaClass(MainActivity.this);mWebView.addJavascriptInterface(javaClass, "testjs");//以下為Java調用Javascript--------------------------//注意://在調用帶參數的Javascript方法時//參數的寫法,如此處的//mWebView.loadUrl("javascript:javacalljswithargs("+"'stringArg'"+")");//不加單引號是錯誤的mButton=(Button) findViewById(R.id.button);mButton.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {                //調用Javascript中的無參方法mWebView.loadUrl("javascript:javacalljs()"); //調用Javascript中帶參數的方法mWebView.loadUrl("javascript:javacalljswithargs("+"'stringArg'"+")");}});}private void initWebViewSettings(){mWebView.setVerticalScrollBarEnabled(false);mWebView.setHorizontalScrollBarEnabled(false);mWebView.getSettings().setJavaScriptEnabled(true);mWebView.getSettings().setSupportZoom(true);mWebView.getSettings().setDomStorageEnabled(true);mWebView.getSettings().setPluginsEnabled(true);mWebView.requestFocus();mWebView.getSettings().setUseWideViewPort(true);mWebView.getSettings().setLoadWithOverviewMode(true);mWebView.getSettings().setSupportZoom(true);mWebView.getSettings().setBuiltInZoomControls(true);}}

JavaClass如下:

package cn.testjavascript;import android.content.Context;import android.widget.Toast;public class JavaClass {private Context mContext;public JavaClass(Context context) {this.mContext=context;}public void firstFunction() {Toast.makeText(mContext, "Javascipt調用Java中的方法,未攜帶參數", Toast.LENGTH_SHORT).show();}public void secondFunction(String string) {Toast.makeText(mContext, "Javascipt調用Java中的方法,攜帶參數為:"+string, Toast.LENGTH_SHORT).show();}}

 

main.xml如下:

<RelativeLayout     xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    >    <WebView        android:id="@+id/webView"        android:layout_width="fill_parent"        android:layout_height="370dip"        android:layout_centerHorizontal="true"     />    <Button         android:id="@+id/button"        android:layout_width="fill_parent"        android:layout_height="wrap_content"        android:text="點擊後Java調用Javascript"        android:layout_alignParentBottom="true"      /></RelativeLayout>

test.html如下:

<html><head><meta http-equiv="Content-Type"content="text/html;charset=gb2312"><script type="text/javascript">function javacalljs(){ document.getElementById("content").innerHTML +=            "<br\>java調用了javascript函數,未帶參數";}function javacalljswithargs(arg){ document.getElementById("content").innerHTML +=            ("<br\>java調用了javascript函數,參數為:"+arg);}</script></head><body>測試Android與Javascript的互動<br/><br><a onClick="window.testjs.firstFunction()">點擊後Javascript調用java代碼</a><br/><br><a onClick="window.testjs.secondFunction('arg')" >點擊後Javascript調用java代碼並攜帶參數</a><br/><br><div id="content">以下為java調用Javascript時的提示資訊:</div></body></html>

 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.