WebView---Android与js交互实例

article/2025/9/17 17:24:48

Android 中可以通过webview来实现和js的交互,在程序中调用js代码,只需要将webview控件的支持js的属性设置为true


Android(Java)与JavaScript(HTML)交互有四种情况:

1) Android(Java)调用HTML中js代码

2) Android(Java)调用HTML中js代码(带参数)

3) HTML中js调用Android(Java)代码

4) HTML中js调用Android(Java)代码(带参数)


下面示例总结这四种情况,直接上干货:


1) Android(Java)

[java] view plain copy print ?
  1. private void showWebView(){     // webView与js交互代码  
  2.     try {  
  3.         mWebView = new WebView(this);  
  4.         setContentView(mWebView);  
  5.           
  6.         mWebView.requestFocus();  
  7.           
  8.         mWebView.setWebChromeClient(new WebChromeClient(){  
  9.             @Override  
  10.             public void onProgressChanged(WebView view, int progress){  
  11.                 JSAndroidActivity.this.setTitle("Loading...");  
  12.                 JSAndroidActivity.this.setProgress(progress);  
  13.                   
  14.                 if(progress >= 80) {  
  15.                     JSAndroidActivity.this.setTitle("JsAndroid Test");  
  16.                 }  
  17.             }  
  18.         });  
  19.           
  20.         mWebView.setOnKeyListener(new View.OnKeyListener() {        // webview can go back  
  21.             @Override  
  22.             public boolean onKey(View v, int keyCode, KeyEvent event) {  
  23.                 if(keyCode == KeyEvent.KEYCODE_BACK && mWebView.canGoBack()) {  
  24.                     mWebView.goBack();  
  25.                     return true;  
  26.                 }  
  27.                 return false;  
  28.             }  
  29.         });  
  30.           
  31.         WebSettings webSettings = mWebView.getSettings();  
  32.         webSettings.setJavaScriptEnabled(true);  
  33.         webSettings.setDefaultTextEncodingName("utf-8");  
  34.   
  35.         mWebView.addJavascriptInterface(getHtmlObject(), "jsObj");  
  36.         mWebView.loadUrl("http://192.168.1.121:8080/jsandroid/index.html");  
  37.     } catch (Exception e) {  
  38.         e.printStackTrace();  
  39.     }  
  40. }  
  41.   
  42. private Object getHtmlObject(){  
  43.     Object insertObj = new Object(){  
  44.         public String HtmlcallJava(){  
  45.             return "Html call Java";  
  46.         }  
  47.           
  48.         public String HtmlcallJava2(final String param){  
  49.             return "Html call Java : " + param;  
  50.         }  
  51.           
  52.         public void JavacallHtml(){  
  53.             runOnUiThread(new Runnable() {  
  54.                 @Override  
  55.                 public void run() {  
  56.                     mWebView.loadUrl("javascript: showFromHtml()");  
  57.                     Toast.makeText(JSAndroidActivity.this"clickBtn", Toast.LENGTH_SHORT).show();  
  58.                 }  
  59.             });  
  60.         }  
  61.           
  62.         public void JavacallHtml2(){  
  63.             runOnUiThread(new Runnable() {  
  64.                 @Override  
  65.                 public void run() {  
  66.                     mWebView.loadUrl("javascript: showFromHtml2('IT-homer blog')");  
  67.                     Toast.makeText(JSAndroidActivity.this"clickBtn2", Toast.LENGTH_SHORT).show();  
  68.                 }  
  69.             });  
  70.         }  
  71.     };  
  72.       
  73.     return insertObj;  
  74. }  


2) js(HTML)

[html] view plain copy print ?
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2. <!-- saved from url=(0032)http://localhost:8080/jsandroid/ -->  
  3. <html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
  4.   
  5. <meta http-equiv="Expires" content="0">  
  6. <meta http-equiv="Pragma" content="no-cache">  
  7. <meta http-equiv="Cache-Control" content="no-store,no-cache">   
  8. <meta name="Handheldfriendly" content="true">  
  9. <meta name="viewport" content="width=100%; initial-scale=1.0; user-scalable=yes">  
  10. <meta name="robots" content="all">  
  11. <meta name="keywords" contect="doodle, mobile, doodlemobile, game, games">  
  12. <meta name="description" content="Make People's Mobile Life More Connected Through Games.">  
  13.   
  14. <title>jsandroid_test</title>  
  15.   
  16. <script type="text/javascript" language="javascript">   
  17.       
  18.     function showHtmlcallJava(){  
  19.         var str = window.jsObj.HtmlcallJava();  
  20.         alert(str);  
  21.     }  
  22.       
  23.     function showHtmlcallJava2(){  
  24.         var str = window.jsObj.HtmlcallJava2("IT-homer blog");  
  25.         alert(str);  
  26.     }  
  27.       
  28.     function showFromHtml(){  
  29.         document.getElementById("id_input").value = "Java call Html";  
  30.     }  
  31.       
  32.     function showFromHtml2( param ){  
  33.         document.getElementById("id_input2").value = "Java call Html : " + param;   
  34.     }  
  35. </script>  
  36. </head>  
  37.   
  38.   
  39. <body>  
  40.   
  41. hello IT-homer  
  42.   
  43. <br>  
  44. <br>  
  45. <br>  
  46.   
  47. <input type="button" value="HtmlcallJava" onclick="showHtmlcallJava()" />  
  48. <br>  
  49. <input type="button" value="HtmlcallJava2" onclick="showHtmlcallJava2()" />  
  50.   
  51. <br>  
  52. <br>  
  53. <br>  
  54. <br>  
  55.   
  56. <input id="id_input" style="width: 90%" type="text" value="null" />  
  57. <br>  
  58. <input type="button" value="JavacallHtml" onclick="window.jsObj.JavacallHtml()" />  
  59.   
  60. <br>  
  61. <br>  
  62. <br>  
  63.   
  64. <input id="id_input2" style="width: 90%" type="text" value="null" />  
  65. <br>  
  66. <input type="button" value="JavacallHtml2" onclick="window.jsObj.JavacallHtml2()" />  
  67.   
  68. </body>  
  69. </html>  


3) 运行结果:




4) 代码解析:

(1) 允许Android执行js脚本设置

Android(Java)与js(HTML)交互的接口函数是: mWebView.addJavascriptInterface(getHtmlObject(), "jsObj");     // jsObj 为桥连对象

Android容许执行js脚本需要设置: webSettings.setJavaScriptEnabled(true);



(2) js(HTML)访问Android(Java)代码

js(HTML)访问Android(Java)端代码是通过jsObj对象实现的,调用jsObj对象中的函数,如: window.jsObj.HtmlcallJava()



(3) Android(Java)访问js(HTML)代码

Android(Java)访问js(HTML)端代码是通过loadUrl函数实现的,访问格式如:mWebView.loadUrl("javascript: showFromHtml()");



说明:

1) Android访问url网址,需在AndroidManifest.xml文件,配置容许访问网络的权限:
<uses-permission android:name="android.permission.INTERNET" />


2) Android(Java)调用js(HTML)时,使用的mWebView.loadUrl("javascript: showFromHtml()");函数需在UI线程运行,因为mWebView为UI控件

[java] view plain copy print ?
  1. public void JavacallHtml(){  
  2.     runOnUiThread(new Runnable() {  
  3.         @Override  
  4.         public void run() {  
  5.             mWebView.loadUrl("javascript: showFromHtml()");  
  6.             Toast.makeText(JSAndroidActivity.this"clickBtn", Toast.LENGTH_SHORT).show();  
  7.         }  
  8.     });  
  9. }  


源码下载


http://chatgpt.dhexx.cn/article/CFSsxXnD.shtml

相关文章

【Android】WebView控件最全使用解析

WebView控件最全使用解析 一、WebView 概述二、WebView使用基础篇2.1添加方式2.2 加载远程网页2.3 加载本地网页2.4 加载HTML片段2.5 WebView 常用方法 三、WebView 进阶篇3.1 WebSettings类3.2 WebViewClient类常见方法使用案例 3.3 WebChromeClient类常用方法使用案例测试网页…

Android:这是一份全面 详细的Webview使用攻略

前言 现在很多App里都内置了Web网页&#xff08;Hybrid App&#xff09;&#xff0c;比如说很多电商平台&#xff0c;淘宝、京东、聚划算等等&#xff0c;如下图 京东首页 那么这种该如何实现呢&#xff1f;其实这是Android里一个叫WebView组件实现 今天&#xff0c;我将献…

数据字典的代码示例

数据字典UI设计&#xff1a; 设计说明&#xff1a; 1. 该数据字典支持多级节点。 2. 左边是数据字典树&#xff1b;右边是编辑框&#xff0c;可以对某个数据字典及其一级子节点进行编辑。 代码&#xff1a;https://github.com/tinazhao1985/spring-cloud-demo/tree/master/di…

关于SQL数据字典的详解

相信在学习数据库的时候很多人在设计表的时候会将一些数据量少的数据放到一个表里面 然后使数据库的表比较多。但是其实呢我们可以见那先数据固定的数据放在同一个表里面&#xff0c;这样就 可以减少很多表的创建&#xff0c;这就是数据字典 数据字典分两个表&#xff1a; 一个…

Java 数据字典的实现

Java数据字典实现 目录概述需求&#xff1a; 设计思路实现思路分析1.从数据库中字典2.获取字典的数值 拓展实现性能参数测试&#xff1a; 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip h…

数据字典功能

1. 什么是数据字典 数据字典存储有关数据的来源、说明、与其他数据的关系、用途和格式等信息&#xff0c;它本身就 是一个数据库&#xff0c;存储“关于数据项的数据”。数据字典是个指南&#xff0c;它为数据库提供了“路线图”&#xff0c; 而不是“原始数据”。换句话说&…

数据字典实现

目录 前言 一、创建springboot的工程&#xff0c;pom文件 二、实体类&#xff0c;mapper层&#xff0c;service层&#xff0c;controller层 1.实体类 2.mapper层 3.service层 4.service实现层简称(serviceImpl) 5.controller层 实现效果&#xff1a; 前言 首先在写数据字典之前…

数据库设计之数据字典的使用与设计

如何使用数据字典 文章目录 如何使用数据字典使用场景 :解决方案 :简单解决&#xff1a;企业级理解&#xff1a;数据字典是什么&#xff1a;使用数据字典的优点&#xff1a; 使用场景 : 在平时开发的过程中&#xff0c;特别是在遇到表单时候&#xff0c;我们经常需要为前端提供…

数据库 - 数据字典及其使用

1 数据字典 1.1 什么是数据字典 将如下这些具有相同类型的配置项&#xff0c;配置到系统的数据字典表中&#xff0c;方便系统维护&#xff0c;由超级管理员统一在后台进行数据字典维护&#xff0c;如果用户需求要增加变更配置项&#xff0c;只需要修改数据字典表记录…

字典的数据处理与可视化

数据处理与可视化 字典数据处理实现数据可视化字典 首先,我们先简单了解一下字典。字典是一个无序、可变和有索引的集合。在 Python 中,字典用花括号表示,拥有键和值。如:{‘id’:1211,‘colors’:‘aliceblue’} 。而字典中包含有字典,称为嵌套字典。如:{‘id’:1211,‘…

数据字典及其使用

1 数据字典 1.1 什么是数据字典 将如下这些具有相同类型的配置项&#xff0c;配置到系统的数据字典表中&#xff0c;方便系统维护&#xff0c;由超级管理员统一在后台进行数据字典维护&#xff0c;如果用户需求要增加变更配置项&#xff0c;只需要修改数据字典表记录…

软件工程~数据字典例子解释

软件工程~数据字典&#xff08;个人理解&#xff09; 数据字典&#xff1a;关于数据的信息的集合&#xff0c;也就是对数据流图中包含的所有元素的定义的集合。 如果开发小型软件系统时暂时没有数据字典的处理程序&#xff0c;建议使用卡片形式书写数据字典&#xff0c;这里先看…

java静态内部类单例的好处,你确定你的单例模式真的用对了?

一、什么是单例模式 单例模式是一种常用的软件设计模式&#xff0c;其定义是单例对象的类只能允许一个实例存在。该类负责创建自己的对象&#xff0c;同时确保只有一个对象被创建。一般常用在工具类的实现或创建对象需要消耗资源的业务场景。 单例模式的特点&#xff1a; 1.类构…

Java静态内部类单例模式读取Properties配置文件

在Java开发中&#xff0c;可能需要把一些配置参数写入properties配置文件中&#xff0c;在这里介绍一种通过静态内部类单例模式来读取的properties文件的方式。 1.properties文件配置路径 在resources下新建配置文件test.properties&#xff0c;如果对于Java读取指定资源输入…

单例模式的四种实现方式(饿汉模式、懒汉模式、静态内部类、枚举类)

首先&#xff0c;设计模式是我们程序员在软件开发过程中面临的一般问题的解决方案&#xff0c;通过学习设计模式可以使我们在编程时更加有条理性&#xff0c;同时培养我们写代码的思维能力&#xff0c;从而提高我们的工作效率。接下来就跟着博主的脚步往下走吧~ 大多数程序员可…

设计模式-静态内部类方式被反射破坏和饿汉式单例模式被序列化破坏解决方式

场景 设计模式-单例模式-饿汉式单例模式、懒汉式单例模式、静态内部类在Java中的使用示例&#xff1a; 设计模式-单例模式-饿汉式单例模式、懒汉式单例模式、静态内部类在Java中的使用示例_霸道流氓气质的博客-CSDN博客 上面静态内部类单例模式示例 package com.ruoyi.demo…

内部类加载顺序及静态内部类单例模式

加载一个类时&#xff0c;其内部类是否同时被加载&#xff1f;下面我们做一个实验来看一下。 Java代码 public class Outer { static { System.out.println("load outer class..."); } //静态内部类 static class Stati…

java静态内部类单例模式_单例模式-静态内部类实现及原理剖析

以我的经验为例(如有不对欢迎指正)&#xff0c;在生产过程中&#xff0c;经常会遇到下面两种情况&#xff1a; 1.封装的某个类不包含具有具体业务含义的类成员变量&#xff0c;是对业务动作的封装&#xff0c;如MVC中的各层(HTTPRequest对象以Threadlocal方式传递进来的)。 2.某…

C# 静态内部类单例模式-静态变量何时初始化

对于一个类的静态变量何时初始化&#xff0c;大家都有一个普遍的共识&#xff0c;那就是第一次使用该类时&#xff0c;初始化该类的所有静态变量和静态方法。 /// <summary>/// 只有在第一次使用到Test1的时候&#xff0c;才会初始化Test1.x/// </summary>class Te…

静态内部类实现单例_单例模式详解

概述 单例模式,是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例的特殊类。通过单例模式可以保证系统中,使用单例模式的类只有一个对象实例。 单例应用场景 Windows系统的任务管理器。Windows系统的回收站。操作系统的文件系统,一个操作系统只能有一个文件系…