Android与Javascript交互示例(二)

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;
	@Override
	protected 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.secondFunction
		JavaClass 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() {
			@Override
			public 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>

 

时间: 2024-11-05 04:54:58

Android与Javascript交互示例(二)的相关文章

Android与Javascript交互示例(一)

MainActivity如下: package cn.testjavascript; import android.os.Bundle; import android.webkit.WebChromeClient; import android.webkit.WebView; import android.app.Activity; /** * Demo描述: * JavaScript调用Android中的方法 * 即点击Html中按钮,调用Android中的方法 * * 参考资料: * htt

Android与Javascript交互示例(三)

MainAcivity如下: package cn.testjavascriptdialog; import android.os.Bundle; import android.app.Activity; import android.app.AlertDialog; import android.app.AlertDialog.Builder; import android.app.Dialog; import android.content.DialogInterface; import a

Android中AutoCompleteTextView完整示例(二)

MainActivity如下: package cc.testautocompletetextview2; import android.os.Bundle; import android.app.Activity; /** * Demo描述 * 利用自定义AutoCompleteTextView完成邮箱自动补全功能 * * 参考资料: * 1 http://blog.csdn.net/fx_sky/article/details/9326129 * 2 http://blog.csdn.net

javascript-Android和JavaScript交互问题

问题描述 Android和JavaScript交互问题 我想在Android的原生页面获取到HTML5页面中的显示的字段然后先原生显示出来,用什么方法 解决方案 读取到html页面,通过解析dom或者正则匹配找出 解决方案二: 你可以通过webView来调用显示html5的页面啊,设置WebSettings.setJavaScriptEnabled(true);使webview可以与JS交互 解决方案三: webview与js交互http://blog.csdn.net/chenfeng0104

重新想象 Windows 8.1 Store Apps (80) - 控件增强: WebView 之基本应用, POST 数据, 与 JavaScript 交互

原文:重新想象 Windows 8.1 Store Apps (80) - 控件增强: WebView 之基本应用, POST 数据, 与 JavaScript 交互 [源码下载] 重新想象 Windows 8.1 Store Apps (80) - 控件增强: WebView 之基本应用, POST 数据, 与 JavaScript 交互 作者:webabcd 介绍重新想象 Windows 8.1 Store Apps 之控件增强 WebView 的基本应用 WebView 通过 POST 请

Android中Java和JavaScript交互实例_Android

Android提供了一个很强大的WebView控件用来处理Web网页,而在网页中,JavaScript又是一个很举足轻重的脚本.本文将介绍如何实现Java代码和Javascript代码的相互调用. 如何实现 实现Java和js交互十分便捷.通常只需要以下几步. 1.WebView开启JavaScript脚本执行 2.WebView设置供JavaScript调用的交互接口. 3.客户端和网页端编写调用对方的代码. 本例代码 为了便于讲解,先贴出全部代码 Java代码 复制代码 代码如下: pack

Android 中Java和JavaScript交互入门

如何实现JavaScript 和java 交互 实现Java和js交互十分便捷.通常只需要以下几步. WebView开启JavaScript脚本执行 WebView设置供JavaScript调用的交互接口. 客户端和网页端编写调用对方的代码. #直接看示例代码: java代码如下:   package com.ccb.javascript; import java.net.URISyntaxException; import android.annotation.SuppressLint; im

Android编程使用WebView实现与Javascript交互的方法【相互调用参数、传值】

本文实例讲述了Android编程使用WebView实现与Javascript交互的方法.分享给大家供大家参考,具体如下: Android中可以使用WebView加载网页,同时Android端的Java代码可以与网页上的JavaScript代码之间相互调用. 效果图: (一)Android部分: 布局代码: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools=&qu

Android中Java和JavaScript交互实例

Android提供了一个很强大的WebView控件用来处理Web网页,而在网页中,JavaScript又是一个很举足轻重的脚本.本文将介绍如何实现Java代码和Javascript代码的相互调用. 如何实现 实现Java和js交互十分便捷.通常只需要以下几步. 1.WebView开启JavaScript脚本执行 2.WebView设置供JavaScript调用的交互接口. 3.客户端和网页端编写调用对方的代码. 本例代码 为了便于讲解,先贴出全部代码 Java代码 复制代码 代码如下: pack