Android-----js和android的互调

 
http://code.google.com/p/apps-for-android/source/browse/trunk/Samples/WebViewDemo/

我对其进行了修改,并加了简单的注释,这个例子的不仅是对js的操作,它还对android浏览器做了简单的介绍, 
这些我会在注释中一一讲解。

Javascript弹出框有如下三种:

  1. alert();
  2. window.confirm("Are you srue?");
  3. window.prompt("Please input some word";,"this is text");

WebChromeClient 中对三种dialog进行了捕捉,但不幸的是,并没有回调函数可以使用, 
或者说不能获得用户是点击“OK”还是“CANCEL”的操作结果。 
个人以为,这些方法的设置是为了对一些涉及到html操作的应用程序进行测试时使用的。 
在WebChromeClient中还有以下的方法:

  1. onProgressChanged(WebView view, int newProgress);
  2. onReceivedIcon(WebView view, Bitmap icon);
  3. onReceivedTitle(WebView view, String title);
  4. onRequestFocus(WebView view);
  5. onCloseWindow(WebView window);
  6. onProgressChanged(WebView view, int newProgress)

这些方法的使用我会在以后的博文中讲到. 
请大家先看今天讲解的重点

  1. public class WebViewDemo extends Activity {
  2. private static final String LOG_TAG = "WebViewDemo";
  3. private WebView mWebView;
  4. private TextView mReusultText ;
  5. private Handler mHandler = new Handler();
  6. @Override
  7. public void onCreate(Bundle icicle) {
  8. super.onCreate(icicle);
  9. setContentView(R.layout.main);
  10. //获得浏览器组件
  11. //WebView就是一个简单的浏览器
  12. //android浏览器源码存在于LINUX\android\package\apps\Browser中
  13. //里面的所有操作都是围绕WebView来展开的
  14. mWebView = (WebView) findViewById(R.id.webview);
  15. mReusultText = (TextView) findViewById(R.id.resultText);
  16. //WebSettings 几乎浏览器的所有设置都在该类中进行
  17. WebSettings webSettings = mWebView.getSettings();
  18. webSettings.setSavePassword(false);
  19. webSettings.setSaveFormData(false);
  20. webSettings.setJavaScriptEnabled(true);
  21. webSettings.setSupportZoom(false);
  22. mWebView.setWebChromeClient(new MyWebChromeClient());
  23. /*
  24. * DemoJavaScriptInterface类为js调用android服务器端提供接口
  25. * android 作为DemoJavaScriptInterface类的客户端接口被js调用
  26. * 调用的具体方法在DemoJavaScriptInterface中定义:
  27. * 例如该实例中的clickOnAndroid
  28. */
  29. mWebView.addJavascriptInterface(new DemoJavaScriptInterface(),"androd");
  30. mWebView.loadUrl("file:///android_asset/page.html");
  31. }
  32. final class DemoJavaScriptInterface {
  33. DemoJavaScriptInterface() {}
  34. /**
  35. * 该方法被浏览器端调用
  36. */
  37. public void clickOnAndroid() {
  38. mHandler.post(new Runnable() {
  39. public void run() {
  40. //调用js中的onJsAndroid方法
  41. mWebView.loadUrl("javascript:onJsAndroid()");
  42. }
  43. });
  44. }
  45. }
  46. /**
  47. * 继承WebChromeClient类
  48. * 对js弹出框时间进行处理
  49. *
  50. */
  51. final class MyWebChromeClient extends WebChromeClient {
  52. /**
  53. * 处理alert弹出框
  54. */
  55. @Override
  56. public boolean onJsAlert(WebView view,String url,
  57. String message,JsResult result) {
  58. Log.d(LOG_TAG,"onJsAlert:"+message");
  59. mReusultText.setText("Alert:"+message);
  60. //对alert的简单封装
  61. new AlertDialog.Builder(WebViewDemo.this).
  62. setTitle("Alert").setMessage(message).setPositiveButton("OK",
  63. new DialogInterface.OnClickListener() {
  64. @Override
  65. public void onClick(DialogInterface arg0, int arg1) {
  66. //TODO
  67. }
  68. }).create().show();
  69. result.confirm();
  70. return true;
  71. }
  72. /**
  73. * 处理confirm弹出框
  74. */
  75. @Override
  76. public boolean onJsConfirm(WebView view, String url, String message,
  77. JsResult result) {
  78. Log.d(LOG_TAG, "onJsConfirm:"+message);
  79. mReusultText.setText("Confirm:"+message);
  80. result.confirm();
  81. return super.onJsConfirm(view, url, message, result);
  82. }
  83. /**
  84. * 处理prompt弹出框
  85. */
  86. @Override
  87. public boolean onJsPrompt(WebView view, String url, String message,
  88. String defaultValue, JsPromptResult result) {
  89. Log.d(LOG_TAG,"onJsPrompt:"+message);
  90. mReusultText.setText("Prompt input is :"+message);
  91. result.confirm();
  92. return super.onJsPrompt(view, url, message, message, result);
  93. }
  94. }
  95. }
 
分类: Android
 
好文要顶 关注我 收藏该文  
4
0
 
(请您对文章做出评价)
 

Android-----js和android的互调的更多相关文章

  1. [转]JS调用Android里面的方法,Android调用JS里面的方法

    FROM : http://blog.csdn.net/hj563308597/article/details/45197709 Android WebView 在公司Android的开发过程中遇到一 ...

  2. WebView中JS调用Android Method 遇到的坑整理

    WebView是android中常用的一个组件,其作用是展示网页,并让网页和android app进行一些业务逻辑上的交互. 其坑无数,相信用过的都知道,一个一个来解决吧. 1.怎么互调: <! ...

  3. JS调用Android、Ios原生控件

    在上一篇博客中已经和大家聊了,关于JS与Android.Ios原生控件之间相互通信的详细代码实现,今天我们一起聊一下JS调用Android.Ios通信的相同点和不同点,以便帮助我们在进行混合式开发时, ...

  4. Atitit.android js 的键盘按键检测Back键Home键和Menu键事件

    Atitit.android js 的键盘按键检测Back键Home键和Menu键事件 1. onKeyDown @Override public boolean onKeyDown(int keyC ...

  5. WebView中Js与Android本地函数的相互调用

    介绍 随着Html5的普及,html在表现力上不一定比原生应用差,并且有很强的扩展兼容性,所以越来越多的应用是采用Html与Android原生混合开发模式实现. 既然要实现混合开发,那么Js与Andr ...

  6. PhoneGap或者Cordova框架下实现Html5中JS调用Android原生代码

    PhoneGap或者Cordova框架下实现Html5中JS调用Android原生代码 看看新闻网>看引擎>开源产品 0人收藏此文章, 发表于8小时前(2013-09-06 00:39) ...

  7. js和android及ios交互

    Android中Java和JavaScript交互 这种交互,Hybrid App 会用的比较多一点, 本文将介绍如何实现Java代码和Javascript代码的相互调用. Android提供了一个很 ...

  8. WebView之js调用Android类的方法传递数据

    1,具体的思路如下: 在android中写一个Activity,里面写一个webview,这个webview加载本地的一个html文件,显示这个网页,这个网页包括一个用户名和密码的输入框和两个按钮(只 ...

  9. Android JS桥交互("Uncaught ReferenceError: xxx is not defined or xxx has no method")

    网上android和js交互的代码有不少,也很容易搜到.最近在做的项目需要用到js桥,遇到了一些问题,记录下来,希望以后遇到能马上解决掉. 一开始我找的demo是从这个:http://blog.csd ...

  10. js调用android本地java代码

    js调用android本地java代码 当在Android上使用WebView控件开发一个Web应用时,可以创建一个通过Javascript调用Android端java代码的接口.也就是可以通过Jav ...

随机推荐

  1. 表单界面的兼容PC手机端解决方案

    就当写一篇随笔吧~上星期还在做加盟模块(兼容微信端),这星期已经加班做快递扫码模块(react+node),所以我感觉只有弹药备足了才能稍微轻松些应对各种需求.实话说在同个部门的大佬面前差距确实大,如 ...

  2. Thrift入门初探(2)--thrift基础知识详解

    昨天总结了thrift的安装和入门实例,Thrift入门初探--thrift安装及java入门实例,今天开始总结一下thrift的相关基础知识. Thrift使用一种中间语言IDL,来进行接口的定义, ...

  3. JAVA 在程序中存储和修改信息

    1.语句和表达式 计算机程序是一组告诉计算机什么的指令,每一个指令称为语句. 2.指定变量类型 变量名.变量存储的信息类型 整型int(-2.14*109~2.14*109).浮点型float(38位 ...

  4. 关于c# 基础运算符的应用

    运算符 分为5种 1 算数预算符 +,-,*,/,分别为加减乘除 ++为加1,--为减1, 前++   后++  的区别 int a = 10, b = a++;            Console ...

  5. 关于java socket

    1. 关于new Socket()中参数的理解 Server端: 调用ServerSocket serverSocket = new ServerSocket(1287,2);后Server端打开了指 ...

  6. CSS实现覆盖弹窗(效果如JQuery-UI的Dialog)

    原理:定义一个新的div用来覆盖整个页面,再把想要弹出的窗口放在这个div上面 1.定义一个div,设置其隐藏(display:none),用于覆盖整个页面,并设置其CSS属性为: #divBg { ...

  7. Burpsuite暴力破解

    神器:burpsuite 闲话不多说,直接开搞 1.打开文件BurpLoader.jar,进入Proxy--Options,启用代理 2.打开浏览器(IE),进入Internet选项-连接-局域网设置 ...

  8. HTML里为什么不能在<p>标签中嵌套<div>标签

    学习过HTML语言的人都应该知道,在HTML里,有分块级元素和内联元素:例如我们常用到的div,o,ul,dl,table,h1...h6等,这些都是块级元素:而像a,b,i,em,img,span等 ...

  9. 爬取软考试题系列之ip自动代理

    马上5月份有个软件专业等级考试,以下简称软考,为了更好的复习备考,我打算抓取www.rkpass.com网上的软考试题. 以上为背景. 很久没有更新博客园的博客了,所以之前的代码没有及时的贴出来,咱们 ...

  10. Https握手协议以及证书认证

    1. 什么是https Https = http + 加密 + 认证 https是对http的安全强化,在http的基础上引入了加密和认证过程.通过加密和认证构建一条安全的传输通道.所以https可以 ...