<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. cakephp2.x 多个应用程序公用一个核心类库

    环境Windows,apache,cake版本2.3.3 Cake项目路径 D:\wamp\www\Mycakephp 浏览器打开 http://localhost/Mycakephp 能够正常访问到 ...

  2. eclipse报这个错误org.eclipse.swt.SWTError: No more handles (eclipse 和 TeamViewer 冲突)

    错误:  org.eclipse.swt.SWTError: No more handles     at org.eclipse.swt.SWT.error(SWT.java:4387)     a ...

  3. 关于mongodb的mapReduce

    由于nodejs本身的限制,在程序中使用js进行大批量计算效率不高.而V8引擎自身对内存大小的限制(64位系统下1.4G),同样限制了数据规模. 因此,相对于从mongodb中抽出数据进行计算,在mo ...

  4. HTMLTestRunner.py(Python3)

    """A TestRunner for use with the Python unit testing framework. Itgenerates a HTML re ...

  5. POSTMan 快速上手(一图带你玩 Postman )

    POSTMan 快速上手(一图带你玩 Postman ):

  6. Shader Forge学习

    最近学习了一下shader forge,一个屌屌哒插件用来生成shader.尽管其降低了制作shader的难度,但是真的想做出满意的shader的话还是得有一定的shader基础.但是仅仅是做出一些简 ...

  7. TW实习日记:第11、12天

    这两天其实都在做一件事,项目组组长丢了个需求下来,要求完成一个百度地图api的页面.原本以为和之前写微信接口的类似,没想到这次问题这么多.并且在写代码的时候和组长交流不畅导致心情也很差,深刻的反思了一 ...

  8. 利用nohup后台运行jar文件包程序

    Linux 运行jar包命令如下: 方式一: java -jar XXX.jar特点:当前ssh窗口被锁定,可按CTRL + C打断程序运行,或直接关闭窗口,程序退出 那如何让窗口不锁定? 方式二 j ...

  9. 莱布尼兹三角形(C++)

    [问题描述] 如下图所示的三角形,请编程输出图中排在第 n 行从左边数第 m 个位置上的数. [代码展示] # include<iostream># include<cstdio&g ...

  10. NMAP-主机扫描

    1.全面扫描 2.扫描指定段 3.ping扫描 只进行ping操作,十分隐蔽 4.无ping扫描 适用于防火墙禁止ping 5.TCP SYN扫描 6.TCP ACK扫描 7.UDP扫描 8.ICMP ...