近期项目中常常使用Html5而Android与JS调用常常会用到,这里记录一下,測试系统5.0以上。

这里先贴一下源代码

Activity:

package jwzhangjie.com.webviewandjs;

import android.content.Context;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.webkit.JavascriptInterface;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Toast; public class MainActivity extends AppCompatActivity { private WebView webView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = (WebView)findViewById(R.id.webView);
initWebView();
} private void initWebView(){
//设置编码
webView.getSettings().setDefaultTextEncodingName("utf-8");
//支持js
webView.getSettings().setJavaScriptEnabled(true);
//设置监听事件
webView.setWebViewClient(new JieWewViewClient());
//设置本地调用对象及其接口
webView.addJavascriptInterface(new JavaScriptObject(getApplicationContext()), "toAndroid");
//载入js
webView.loadUrl("file:///android_asset/index.html");
} public void javaCallJsNoParams(View view){
webView.loadUrl("javascript:javaCallJsNoParamsMethod()");
} public void javaCallJsHasParams(View view){
webView.loadUrl("javascript:javaCallJsHasParamsMethod('" + 123 + "')");
} public class JavaScriptObject { Context mContxt; public JavaScriptObject(Context mContxt) {
this.mContxt = mContxt;
} @JavascriptInterface //sdk17版本号以上加上注解
public void jsCallJavaNoParams() {
Toast.makeText(mContxt, "Js调用Java方法(无參)", Toast.LENGTH_LONG).show();
} @JavascriptInterface //sdk17版本号以上加上注解
public void jsCallJavaHasParams(String params) {
Toast.makeText(mContxt, "Js调用Java方法(有參):" + params, Toast.LENGTH_SHORT).show();
}
} class JieWewViewClient extends WebViewClient{
/**
* 假设紧跟着
* webView.loadUrl("file:///android_asset/index.html");
* 调用Js中的方法是不起作用的,必须页面载入完毕才干够
*/ @Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
webView.loadUrl("javascript:javaCallJsHasParamsMethod('" + 123 + "')");
}
} }

html:

<!DOCTYPE HTML>
<HTML>
<HEAD>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
</HEAD>
<BODY>
<div>
<input type="text" id="showText" style="width:100%;height:100px;margin-bottom:10px" readonly>
<input type="button" onclick="jsCallJavaNoParamsMethod()" value="Js调用Java方法(无參)">
<input type="button" onclick="jsCallJavaHasParamsMethod('成功了')" value="Js调用Java方法(有參)">
</div>
</BODY>
<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript">
function javaCallJsNoParamsMethod(){
$('#showText').val("Java调用js方法,无參数");
} function javaCallJsHasParamsMethod(params){
$('#showText').val("Java调用Js方法。有參数:"+params);
} function jsCallJavaNoParamsMethod(){
toAndroid.jsCallJavaNoParams();
} function jsCallJavaHasParamsMethod(params){
toAndroid.jsCallJavaHasParams(params);
}
</script>
</HTML>

界面:

注意点:

1、Android系统17以及以上,js调用java须要在方法上面增加@JavascriptInterface

2、不能在载入html页面的以下直接调用js方法,应该在WebViewClient的onPageFinished里面载入,原则就是必须html载入完毕后。才干调用js中的方法。

源代码:http://download.csdn.net/download/jwzhangjie/9020941

Android与JS互相调用以及注意的更多相关文章

  1. Android与js互相调用

    有话要说: 本篇主要总结了简单的Android与js互相调用的方法. 在开发过程中遇到了需要在安卓中调用js方法的需求,于是将具体的实现过程总结成这篇博客. 效果: 其中“调用安卓方法”按钮是html ...

  2. android和js互相调用

    import android.app.Activity; import android.content.Intent; import android.net.Uri; import android.o ...

  3. Android 使用js调用Java

    效果如: 主要用到一个接口类:MyObject package com.example.jsdemo; import android.content.Context; import android.s ...

  4. Android与JS混编(js调用java)

    项目中需要使用android与js的混编来开发app. 下面就介绍一下吧. 有时候我们需要用js调用native控件,要想实现这个功能,我们需要做的就只有三步: 1.允许webview执行js脚本 2 ...

  5. Android开发学习之路--Java和Js互相调用

      随着前端的火热,以前开发的快速,越来越多的native app在其中融合了h5,就拿淘宝就是很多的h5组成的,一旦出现什么节日,他都可以不用通过更新app来实现界面的改变,而且android和io ...

  6. android js 互相调用

    代码地址如下:http://www.demodashi.com/demo/13107.html android js 互相调用 第二版 支持js匿名函数接收 支持js json对象接收 支持js函数返 ...

  7. Android和JavaScript相互调用的方法

    转载地址:http://www.jb51.net/article/77206.htm 这篇文章主要介绍了Android和JavaScript相互调用的方法,实例分析了Android的WebView执行 ...

  8. Android-webview和js互相调用

    Android-webview和js互相调用 Android 和 H5 都是移动开发应用的非常广泛.市面上很多App都是使用Android开发的,但使用Android来开发一些比较复杂附属类,提示性的 ...

  9. android webview js交互 第一节 (java和js交互)

    转载请注明出处         挺帅的移动开发专栏  http://blog.csdn.net/wangtingshuai/article/details/8631835        在androi ...

随机推荐

  1. Java学习笔记之从C++转Java

    之前一直是做C++后台开发的,习惯了命令行和g++,由于工作原因现在开始转java. 1.参考书籍:java编程思想(think in java),java核心技术(core java); 2.怎么在 ...

  2. php统计网站 / html页面 浏览访问次数程序

    本文章来给大这介绍了php自己写的一些常用的网站统计代码写法,用无数据库的与使用数据库及html静态页面浏览资次数统计代码,大家可进入参考. 实例1 直接使用txt文件进行统计的代码 <?php ...

  3. Coursera公开课-Machine_learing:编程作业6

    Support Vector Machines I have some issues to state. First, there were some bugs in original code wh ...

  4. 5.14web相关概念

    1.软件架构 1.C/S:客户端/服务器端 2.B/S:浏览器/服务器端 2.资源分类 1.静态资源:所有用户访问后,得到的结果都是一样的,称为静态资源.静态资源可以直接被浏览器解析如:html,cs ...

  5. poj1328 Radar Installation 区间贪心

    题目大意: 在X轴选择尽量少的点作为圆心,作半径为d的圆.使得这些圆能覆盖所有的点. 思路: 把每个点都转化到X轴上.也就是可以覆盖这个点的圆心的位置的范围[a,b].然后按照每个点对应的a从小到大排 ...

  6. ajax-工作原理,包含技术,缺陷

    1:原理 2:包含技术 3:缺陷

  7. 【VB】时间戳转日期

    DateAdd("s", TimeStamp / 1000, "1970-01-01 00:00:00")

  8. dubbo之启动时检查

    启动时检查 Dubbo缺省会在启动时检查依赖的服务是否可用,不可用时会抛出异常,阻止Spring初始化完成,以便上线时,能及早发现问题,默认 check="true".所以可以通过 ...

  9. c#动态类型Dynamic

    需引用System.Dynamic命名空间 来源:http://www.cnblogs.com/ryanding/archive/2010/12/09/1900106.html dynamic Cus ...

  10. pycharm主题 变量颜色 自定义

    File--Settings--Edtior--Color Schame-- Lanuage Defaults