[转]JS调用Android里面的方法,Android调用JS里面的方法
FROM : http://blog.csdn.net/hj563308597/article/details/45197709
Android WebView
在公司Android的开发过程中遇到一个新的问题,那就是让android代码和Javascript代码进行交互,然后在网上找到了关于webView的资料,之前并没有深入去了解WebView,一直以为Android 的WebView是一个用来显示网页的组件而已,没想到功能如此强大,竟然能跟JS互调传参,太牛了!
1、什么是webView?
WebView是一个webkit的内核,android对其做了很好的优化跟封装,主要用来处理网页相关的问题,盗图一张
2、webView相关类的作用可以去查api,网站上面也很多,主要就是WebChromeClient,WebViewClient、WebSettings几个类,比较关键的就是加载本地js网页跟网络js网页的时候要有点区别,注意权限跟访问方式有点点区别,下面贴代码:
- package com.chinaonenet.mywebview;
- import android.annotation.SuppressLint;
- import android.app.Activity;
- import android.os.Bundle;
- import android.os.Handler;
- import android.view.Menu;
- import android.view.MenuItem;
- import android.view.View;
- import android.view.View.OnClickListener;
- import android.webkit.WebSettings;
- import android.webkit.WebView;
- import android.widget.Button;
- /**
- * @author hujun
- *
- * QQ:563008597
- *
- * SuppressLint一定要加上去!!!
- * 低版本可能没问题,高版本JS铁定调不了Android里面的方法
- *
- */
- @SuppressLint("SetJavaScriptEnabled")
- public class MainActivity extends Activity {
- //声明一个webview
- private WebView mWebView;
- private MyWebViewClient WVClient;
- private WebSettings webSettings;
- private MyWebChromeClient chromeClient;
- //测试Button,忽略就行
- private Button testBtn;
- //调用JS的Button
- private Button callJSBtn;
- //双击返回退出应用
- private long exitTime = 0;
- //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);
- testBtn = (Button)findViewById(R.id.diyWeb);
- 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.TEST_NET);
- mWebView.setWebViewClient(WVClient);
- mWebView.setWebChromeClient(chromeClient);
- //注意第二个参数JsTest,这个是JS网页调用Android方法的一个类似ID的东西
- mWebView.addJavascriptInterface(jsobject, "JsTest");
- //测试自定义网页,忽略
- testBtn.setOnClickListener(new OnClickListener() {
- @Override
- public void onClick(View v) {
- // TODO Auto-generated method stub
- String str = "test my web";
- mWebView.loadData("<html><body>"+str+"<html><body>", "text/html", "UTF-8");
- }
- });
- //调用JS网页
- callJSBtn.setOnClickListener(new OnClickListener() {
- @Override
- public void onClick(View v) {
- // TODO Auto-generated method stub
- mHandler.post(new Runnable() {
- @Override
- public void run() {
- // TODO Auto-generated method stub
- //调用JS中的 函数,当然也可以不传参
- mWebView.loadUrl("javascript:androidCallJS('顺便传个参数给JS!')");
- }
- });
- }
- });
- }
- @Override
- public boolean onCreateOptionsMenu(Menu menu) {
- // Inflate the menu; this adds items to the action bar if it is present.
- getMenuInflater().inflate(R.menu.main, menu);
- return true;
- }
- @Override
- public boolean onOptionsItemSelected(MenuItem item) {
- // Handle action bar item clicks here. The action bar will
- // automatically handle clicks on the Home/Up button, so long
- // as you specify a parent activity in AndroidManifest.xml.
- int id = item.getItemId();
- if (id == R.id.action_settings) {
- return true;
- }
- return super.onOptionsItemSelected(item);
- }
- //单击系统返回键网页回退
- @Override
- public void onBackPressed() {
- // TODO Auto-generated method stub
- //if (System.currentTimeMillis() - exitTime > 1500) {
- if (mWebView.canGoBack()) {
- mWebView.goBack();
- }/*else {
- Toast.makeText(this, "再按一次返回键退出", Toast.LENGTH_SHORT).show();
- }
- exitTime = System.currentTimeMillis();
- } */
- else {
- this.finish();
- }
- }
- }
- package com.chinaonenet.mywebview;
- import android.content.Context;
- import android.util.Log;
- import android.webkit.JavascriptInterface;
- import android.widget.Toast;
- public class JSObject {
- /*
- * 绑定的object对象
- * */
- private Context context;
- public JSObject(Context context){
- this.context = context;
- }
- /*
- * JS调用android的方法
- * @JavascriptInterface仍然必不可少
- *
- * */
- @JavascriptInterface
- public String JsCallAndroid(){
- Toast.makeText(context, "JsCallAndroid", Toast.LENGTH_SHORT).show();
- return "JS call Andorid";
- }
- }
下面上传工程下载链接:http://download.csdn.net/detail/hj563308597/8624449
http://www.cnblogs.com/greatverve/archive/2012/01/18/android-javascript.html
[转]JS调用Android里面的方法,Android调用JS里面的方法的更多相关文章
- Android 4.2版本以下使用WebView组件addJavascriptInterface方法存在JS漏洞
JS注入漏洞存在的Android版本:Android < 4.2 综述:Android的SDK中提供了一个WebView组件,用于在应用中嵌入一个浏览器来进行网页浏览.WebView组件中的ad ...
- WebView中Js与Android本地函数的相互调用
介绍 随着Html5的普及,html在表现力上不一定比原生应用差,并且有很强的扩展兼容性,所以越来越多的应用是采用Html与Android原生混合开发模式实现. 既然要实现混合开发,那么Js与Andr ...
- uni-app&H5&Android混合开发三 || uni-app调用Android原生方法的三种方式
前言: 关于H5的调用Android原生方法的方式有很多,在该片文章中我主要简单介绍三种与Android原生方法交互的方式. 一.H5+方法调用android原生方法 H5+ Android开发规范官 ...
- Android中通过WebView控件实现与JavaScript方法相互调用的地图应用
在Android中通过WebView控件,可以实现要加载的页面与Android方法相互调用,我们要实现WebView中的addJavascriptInterface方法,这样html才能调用andro ...
- android开发中关于继承activity类中方法的调用
android开发中关于继承activity类中的函数,不能在其他类中调用其方法. MainActivity.java package com.example.testmain; import and ...
- [android] 绑定方式开启服务&调用服务的方法
需求:后台开启一个唱歌服务,这个服务里面有个方法切换歌曲 新建一个SingService继承系统Service 重写onCreate()和onDestory()方法 填一个自定义的方法changeSi ...
- Android app启动activity并调用onCreate()方法时都默默地干了什么?
Android app启动activity并调用onCreate() 方法时都默默地干了什么? 在AndroidManifest.xml文件中的<intent-filter>元素中有这 ...
- Android -- service的开启方式, start开启和绑定开启服务,调用服务的的方法, aidl调用远程服务
1. 概述 bindService() 绑定服务 可以得到服务的代理人对象,间接调用服务里面的方法. 绑定服务: 间接调用服务里面的方法. 如果调用者activity被销毁了, ...
- Android(安卓)开发通过NDK调用JNI,使用opencv做本地c++代码开发配置方法 边缘检测 范例代码
以前写过两个Android开发配置文档,使用NDK进行JNI开发,这样能够利用以前已经写好的C++代码. 前两篇博客地址: http://blog.csdn.net/watkinsong/articl ...
- Atitit.提升软件Web应用程序 app性能的方法原理 h5 js java c# php python android .net
Atitit.提升软件Web应用程序 app性能的方法原理 h5 js java c# php python android .net 1. 提升单例有能力的1 2. 减少工作数量2 2.1. 减少距 ...
随机推荐
- MVC模式与三层架构和表示层
1.MVC模式 - Model-View-Controller - 模型-视图-控制器 - Model(模型) > 模型分为业务模型,和数据模型 ...
- 在IDEA 上使用Git查看主干和分支等
使用IDEA 查看提交历史时,IDEA默认显示的页面是你当前页面的提交历史: 然后,你点击左侧的 log 键,则可以显示整个团队每个人的提交记录: 在选中每一次的记录以后,会弹出每次提交的所有文件(对 ...
- Sublime Text 收藏笔记
Sublime Text:初学者不知道的那些事 转载自: http://blog.jobbole.com/23949/
- 从Prototype学习JavaScript面向对象编程
概述 JavaScript是一种基于对象的编程语言.它是灵活的,既有面向过程(也就是面向函数)的编程,也有面向对象的编程.因此我称它是基于对象的编程语言. 对于JavaScript的面向过程的编程特性 ...
- Access restriction: The type 'RSACipher' is not API
解决方法: http://stackoverflow.com/questions/860187/access-restriction-on-class-due-to-restriction-on-re ...
- oracle学习笔记系列------oracle操作例子的专用表
CREATE TABLE dept( deptno ), dname ) , loc ) ) ; CREATE TABLE emp( empno ), ename ), job ), mgr ), h ...
- WIN 下的超动态菜单(一)
WIN 下的超动态菜单(一)介绍 WIN 下的超动态菜单(二)用法 WIN 下的超动态菜单(三)代码 作者:黄山松,发表于博客园:http://www.cnblogs.com/tomview/ ...
- 使用Fiddler对Android或者iOS设备进行抓包
1.PC端Fiddler配置 Tools->HTTPS->选中“Decrpt HTTPS traffic”,“Ignore server certificate errors” Tools ...
- hadoop如何处理长时间运行不完成的map/reduce 任务?
如果某一个任务在某个节点上长时间不完成,怎么手动干预来处理这种情况?董西成博客上找到的回答:hadoop中有三种特殊的任务,failed task,killed task和speculative ta ...
- [译] OpenStack Kilo 版本中 Neutron 的新变化
OpenStack Kilo 版本,OpenStack 这个开源项目的第11个版本,已经于2015年4月正式发布了.现在是个合适的时间来看看这个版本中Neutron到底发生了哪些变化了,以及引入了哪些 ...