安卓webview和h5交互

article/2025/9/17 17:07:00

先上html的代码:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<HTML><HEAD><TITLE>安卓和js交互demo</TITLE><meta charset="utf-8"></HEAD><script> function giveAndroidData(content){var str = navigator.userAgent;if(str.indexOf("androidToJsDemo") != -1){android_js.giveAndroidData(content);}	}function getAndroidData(){var str = navigator.userAgent;if(str.indexOf("androidToJsDemo") != -1){alert("获取到安卓数据:" + android_js.getAndroidData());}}  function getData(content){alert("安卓调用了js的getData()方法,js拿到安卓传过来的数据:"+content);return 'bcd';}</script><BODY><button type="button"  onclick="giveAndroidData('js调用了安卓的方法,给安卓传了数据')">调用安卓方法,给安卓传数据</button><br/><br/><button type="button"  onclick="getAndroidData()">调用安卓方法,获取安卓数据</button></BODY>
</HTML>

为了方便各位测试,上面的html代码我放到了自己的腾讯云服务器上,地址:http://123.206.81.43:8080/demo/androidToJsDemo.html

主要有两个按钮,都是js主动调用安卓方法,一个是给安卓传数据,另一个是获取安卓数据。

然后看一下安卓布局代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".MainActivity"><WebViewandroid:id="@+id/webView"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1" /><Buttonandroid:layout_width="match_parent"android:layout_height="wrap_content"android:onClick="getDataFromJs"android:text="安卓调用js方法" />
</LinearLayout>

就一个webview和button,很简单

接下来看一下webview对应的activity代码:

import android.graphics.Bitmap;
import android.os.Build;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.webkit.JavascriptInterface;
import android.webkit.ValueCallback;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Toast;public class MainActivity extends AppCompatActivity {private static final String TAG = "MainActivity";private WebView mWebView;private final String url = "http://123.206.81.43:8080/demo/androidToJsDemo.html";@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);mWebView = findViewById(R.id.webView);WebSettings settings = mWebView.getSettings();settings.setUserAgentString(settings.getUserAgentString() + "androidToJsDemo");settings.setJavaScriptEnabled(true);// 表示支持jssettings.setJavaScriptCanOpenWindowsAutomatically(true);mWebView.addJavascriptInterface(this, "android_js");mWebView.setWebViewClient(new WebViewClient() {@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {view.loadUrl(url);return true;}@Overridepublic void onPageStarted(WebView view, String url, Bitmap favicon) {super.onPageStarted(view, url, favicon);Log.e(TAG, "onPageStarted");}@Overridepublic void onPageFinished(WebView view, String url) {super.onPageFinished(view, url);Log.e(TAG, "onPageFinished");}});//不加这个,js中的alert就不会正常显示,webview只是一个承载体,各种内容的渲染需要使用webviewChromClient去实现,所以set一个默认的基类WebChromeClient就行mWebView.setWebChromeClient(new WebChromeClient() {@Overridepublic void onReceivedTitle(WebView view, String title) {super.onReceivedTitle(view, title);}});mWebView.loadUrl(url);}public void getDataFromJs(View v) {//安卓调用js的方法,并传过去abcif (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) {mWebView.loadUrl("javascript:getData('abc')");} else {mWebView.evaluateJavascript("javascript:getData('abc')", new ValueCallback<String>() {@Overridepublic void onReceiveValue(String value) {//会收到js中getData方法的返回值Log.e(TAG, "onReceiveValue: " + value);}});}}@JavascriptInterface //一定注意不要忘记注解public void giveAndroidData(String content) {//js给安卓传数据toast(content);}@JavascriptInterfacepublic String getAndroidData() {//js调用安卓获取数据return "这是js从安卓获取到的数据123456";}public void toast(String s) {Toast.makeText(this, s, Toast.LENGTH_LONG).show();}}

其中,@JavascriptInterface注解标记的方法,是js能调用的方法

mWebView.addJavascriptInterface(MainActivity.this, "android_js");

是在js中定义了一个android_js对象,所以js中才能直接用android_js对象调用方法,一定要记得在js中通过UA判断是不是在安卓APP下,因为浏览器里面不存在这个对象,是安卓APP里面才有,我一般是在安卓默认的UA后面加上一段项目相关的字符串,方便js判断是否处于安卓APP里(settings.setUserAgentString(settings.getUserAgentString() + "androidToJsDemo");),然后js通过判断androidToJsDemo这段唯一字符串是否存在来判断是否在安卓APP:

        var str = navigator.userAgent;
        if(str.indexOf("androidToJsDemo") != -1){
           //说明处在安卓APP里,不是在浏览器里,也不是ios里
        }

运行截图:点击H5中第一个按钮时,给安卓传过来字符串,安卓通过toast打印出来,如图:

点击第二个按钮获取安卓的数据,将获取到的数据alert出来:

点击安卓原生按钮,调用js方法,如图:

我用的是安卓8.0的模拟器,点击确定以后,可以看到打印出来了js的返回值:

 

 

 


http://chatgpt.dhexx.cn/article/8qFpyQas.shtml

相关文章

Android—WebView与JS交互

Html文件&#xff1a; WebView与JS交互方式&#xff1a; 1. 前提&#xff1a; WebSettings webSettings webView.getSettings(); // 设置与Js交互的权限 webSettings.setJavaScriptEnabled(true);webView.setWebChromeClient(new WebChromeClient(){Overridepublic boolean …

【Android】之【WebView】

一、简介 WebView是一种控件&#xff0c;它基于webkit引擎&#xff0c;因此具备渲染Web页面的功能。   基于Webview的混合开发&#xff0c;就是在 Android os(安卓)/I os(苹果)原生APP里&#xff0c;通过WebView控件嵌入Web页面。 你手机里有淘宝软件吧&#xff1f; 就是外…

WebView---Android与js交互实例

Android 中可以通过webview来实现和js的交互&#xff0c;在程序中调用js代码&#xff0c;只需要将webview控件的支持js的属性设置为true Android&#xff08;Java&#xff09;与JavaScript&#xff08;HTML&#xff09;交互有四种情况&#xff1a; 1&#xff09; Android&…

【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…