<html>
  
  <body>
  
  <script>
  
  function showAlert(){
  
  alert("JavaScript - hello , world !");
  
  }
  
  function showConfirm(){
  
  confirm("访问 https://blog.csdn.net/zhangphil");
  
  }
  
  function showPrompt(){
  
  var string=prompt("请输入用户名","用户名");
  
  }
  
  </script>
  
  <button type="button" id="button1" onclick="showAlert()">showAlert</button>
  
  <br>
  
  <button type="button" id="button2" onclick="showConfirm()">showConfirm</button>
  
  <br>
  
  <button type="button" id="button3" onclick="showPrompt()">showPrompt</button>
  
  </body>
  
  </html>
  
  上层Java代码:
  
  import android.content.DialogInterface;
  
  import android.os.Bundle;
  
  import android.support.v7.app.AlertDialog;
  
  import android.support.v7.app.AppCompatActivity;
  
  import android.webkit.JsPromptResult;
  
  import android.webkit.JsResult;
  
  import android.webkit.WebChromeClient;
  
  import android.webkit.WebSettings;
  
  import android.webkit.WebView;
  
  import android.widget.Toast;
  
  public class MainActivity extends AppCompatActivity {
  
  private WebView mWebView;
  
  @Override
  
  protected void onCreate(Bundle savedInstanceState) {
  
  super.onCreate(savedInstanceState);
  
  setContentView(R.layout.activity_main);
  
  mWebView = findViewById(R.id.webview);
  
  mWebView.loadUrl("file:///android_asset/web.html");
  
  WebSettings mWebSettings = mWebView.getSettings();
  
  //启用JavaScript。
  
  mWebSettings.setJavaScriptEnabled(www.qinlinyu.cn true);
  
  mWebSettings.setUseWideViewPort(true);
  
  mWebSettings.setJavaScriptCanOpenWindowsAutomatically(true);
  
  mWebView.setWebChromeClient(new WebChromeClient() {
  
  // 拦截JavaScript的Alert弹窗。
  
  @Override
  
  public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
  
  Toast.makeText(getApplicationContext(www.michenggw.com), "onJsAlert:" + message + "," + result.toString(), Toast.LENGTH_SHORT).show();
  
  result.confirm();
  
  //true,拦截JavaScript的弹窗。如果拦截了,不会出现弹窗。
  
  //false,不拦截JavaScript的弹窗,由WebView自行决定弹窗。
  
  return true;
  
  }
  
  // 拦截JavaScript的Confirm弹窗。
  
  @Override
  
  public boolean onJsConfirm(WebView view, String url, String message, JsResult result) {
  
  new AlertDialog.Builder(MainActivity.this)
  
  .setTitle("Android拦截JavaScript的Confirm弹窗")
  
  .setMessage(message + " , 确定吗?")
  
  .setPositiveButton("确定访问", new DialogInterface.OnClickListener() {
  
  @Override
  
  public void onClick(DialogInterface dialog, int which) {
  
  result.confirm();
  
  }
  
  })
  
  .setNegativeButton("取消访问", new DialogInterface.OnClickListener() {
  
  @Override
  
  public void onClick(DialogInterface dialog, int which) {
  
  result.cancel(www.dasheng178.com);
  
  }
  
  }).setCancelable(false)www.mingheyl178.com/.show();
  
  //true,拦截JavaScript的弹窗。如果拦截了,不会出现弹窗。
  
  //false,不拦截JavaScript的弹窗,由WebView自行决定弹窗。
  
  return true;
  
  }
  
  @Override
  
  public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, JsPromptResult result) {
  
  System.out.println(result);
  
  result.confirm();
  
  //true,拦截JavaScript的弹窗。如果拦截了,不会出现弹窗。
  
  //false,不拦截JavaScript的弹窗,由WebView自行决定弹窗。
  
  return false;
  
  }
  
  });
  
  }

Android原生代码拦截H5 Web页面中JavaScript弹窗/弹框的更多相关文章

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

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

  2. php中调用这个功能可以在web页面中显示hello world这个经典单词

    php程序写的时间长了,自然对他所提供的功能了如指掌,他所提供的一大堆功能,真是觉得很好用,但有时候会发现php也缺少一些功能,自己总是会产生为php添加一些自定义的功能的想法.久而久之,终于今天憋不 ...

  3. 关于在asp.net的web页面中的全局变量问题

    在asp.net的web页面中是不是没有全局变量?有的,在Class类内部的都是,只不过在WebWofm程式中跟WinForm和Console程式有些区别,当页面刷新时,它们的值不会保持,依然会再次初 ...

  4. [置顶] 读取pdf并且在web页面中显示

    读取pdf并且在web页面中显示 if (System.IO.File.Exists(f)) { Response.ContentType = "applicationpdf"; ...

  5. Android : 如何在WebView显示的页面中查找内容

    Android : 如何在WebView显示的页面中查找内容 Author : Aoyousatuo Zhao http://blog.sina.com.cn/aoyousatuo WebView是A ...

  6. web页面中可以包含多个对象

    # encoding=utf-8 #python 2.7.10 #xiaodeng #web页面中可以包含多个对象 #HTTP权威指南 10页 #应用程序完成一项任务时通常会发布多个http事务.如: ...

  7. 企业级监控软件Zabbix搭建部署之zabbix在WEB页面中的配置

    企业级监控软件zabbix搭建部署之zabbix在WEB页面中的配置 企业级监控软件zabbix搭建部署之zabbix在WEB页面中的配置 关于安装请看 http://www.linuxidc.com ...

  8. 微信开发之移动手机WEB页面(HTML5)Javascript实现一键拨号及短信发送功能

    在做一个微信的微网站中的一个便民服务电话功能的应用,用到移动web页面中列出的电话号码,点击需要实现调用通讯录,网页一键拨号的拨打电话功能. 如果需要在移动浏览器中实现拨打电话,发送email,美国服 ...

  9. [HTML] 微信开发之移动手机WEB页面(HTML5)Javascript实现一键拨号及短信发送功能

    在做一个微信的微网站中的一个便民服务电话功能的应用,用到移动web页面中列出的电话号码,点击需要实现调用通讯录,网页一键拨号的拨打电话功能. 如果需要在移动浏览器中实现拨打电话,发送email,美国服 ...

随机推荐

  1. SpringBoot-01:什么是SpringBoot?

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- SpringBoot: Spring Boot可以轻松创建独立的,生产级的基于Spring的应用程序,您可以“ ...

  2. hadoop 家族图

    hadoop家族

  3. 「功能笔记」性能分析工具gprof使用笔记

    根据网上信息整理所成. 功能与优劣 gprof实际上只是一个用于读取profile结果文件的工具.gprof采用混合方法来收集程序的统计信息,它使用检测方法,在编译过程中在函数入口处插入计数器用于收集 ...

  4. 「专题训练」Machine Schedule(HDU-1150)

    题意 在一个工厂,有两台机器\(A, B\)生产产品.\(A\)机器有\(n\)种工作模式(模式\(0\),模式\(1\)--模式\(n-1\)).\(B\)机器有\(m\)种工作模式(模式\(0\) ...

  5. Appium最新的服务器初始化参数(Capability)【截止11月29日,后续最新的可以看github】

    键 描述 值 automationName 自动化测试的引擎 Appium (默认)或者 Selendroid platformName 使用的手机操作系统 iOS, Android, 或者 Fire ...

  6. JMeter自学笔记3-创建自己的第一个测试用例

    一.写在前面的话: 上篇我们已经认识了JMeter的图形界面,大家应该都是很懵的.那么这篇,我们将学习使用JMeter创建第一个属于自己测试用例. 二.创建自己的第一个测试用例: 1.新建一个Thre ...

  7. Python字符串操作大全(非常全!!!)

    1. python编程里字符串的内置方法(非常全) capitalize() 把字符串的第一个字符改为大写 casefold() 把整个字符串的所有字符改为小写 center(width) 将字符串居 ...

  8. java后台接收微信服务号/订阅号消息

    1.申请订阅号(适合个人)或者服务号(适合企业) 微信公众平台 2.填写配置 服务器地址: 需要接收消息 的服务端接口地址 令牌:通话识别码,随便写,后端接收时,使用一样的就可以了. 消息加密秘钥 : ...

  9. 【转】Unity 使用xLua遇到的坑

    在我们使用xLua作为Unity中lua集成的解决方案时,遇到了一个问题,就是当我们使用在lua中把UI中的某个控件绑定相应的事件(如按钮的onClick事件),xLua绑定这个事件是用委托实现的,具 ...

  10. spark提交任务的两种的方法

    在学习Spark过程中,资料中介绍的提交Spark Job的方式主要有两种(我所知道的): 第一种: 通过命令行的方式提交Job,使用spark 自带的spark-submit工具提交,官网和大多数参 ...