<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. 海思NB-IOT的RA功能

    就带ReleaseAssistance标志的特殊发送指令,发送数据的时候会向网络侧请求立即释放RRC进入Idle态. 降低20秒50mA连接态的能量消耗.

  2. vim 打造IDE

    1.MinBufExplorer 2.Ctags Ctags工具是用来遍历源代码文件生成tags文件,这些tags文件能被编辑器或其它工具用来快速查找定位源代码中的符号(tag/symbol),如变量 ...

  3. javaweb(四)——Http协议(请求头,响应头详解)

    一.什么是HTTP协议 HTTP是hypertext transfer protocol(超文本传输协议)的简写,它是TCP/IP协议的一个应用层协议,用于定义WEB浏览器与WEB服务器之间交换数据的 ...

  4. OSG-获取OSG的源代码和第三方库并编译

    获取OSG的源代码有很多方式. 这里说下其中的两个地方,第一就是中国的OSG网站http://www.osgchina.org/,这个网站目前应该是由中国西安恒歌科技维护,同时,西安恒歌科技也是一家已 ...

  5. Qt-QML-Connections,接受组件信号

    这里还没有什么新的体会.就直接上代码,在上篇一处上改出来的 import QtQuick 2.5 import QtQuick.Controls 1.4 ApplicationWindow { vis ...

  6. Django - day00 第一个页面

    Django - day00 0.写在最前面 第一次接触Django,是在大三的做数据库课程设计的时候,当时好像还是1.8的版本,现转眼就到了2.0的版本. 当时由于没太多的课,仅花了不到一周的时间就 ...

  7. Java开发工程师(Web方向) - 02.Servlet技术 - 第4章.JSP

    第4章--JSP JSP JSP(Java Server Pages) - 中文名:Java服务器页面 动态网页技术标准 JSP = Html + Java + JSP tags 在服务器端执行,返回 ...

  8. Codeforces-A. Shortest path of the king(简单bfs记录路径)

    A. Shortest path of the king time limit per test 1 second memory limit per test 64 megabytes input s ...

  9. 【system.folder】使用说明

    对象:system.folder 说明:提供一系列针对文件夹的操作 目录: 方法 返回 说明 system.folder.exists(folderPath) [True | False] 检测指定文 ...

  10. Python基础 之 set集合 与 字符串格式化

    数据类型的回顾与总结 可变与不可变1.可变:列表,字典2.不可变:字符串,数字,元组 访问顺序:1.直接访问:数字2.顺序访问:字符串,列表,元祖3.映射:字典 存放元素个数:容器类型:列表,元祖,字 ...