我的编程空间,编程开发者的网络收藏夹
学习永远不晚

关于原生android与H5交互的方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

关于原生android与H5交互的方法

文章目录

原生android与H5交互

前面讲解方法,结尾放代码

android调用H5方法

首先需要一个WebView

mWebView = (WebView) findViewById(R.id.webView);mWebView.loadUrl("http://10.20.58.190:8081/");WebSettings webSettings = mWebView.getSettings();webSettings.setJavaScriptEnabled(true);
  • 方法一:使用WebView的loadUrl()方法,以loadUrl(script)的方式调用

android方法:

mWebView.loadUrl("javascript:test1Fun('使用这种方法无法取得返回参数,且会刷新页面,如果js函数有返回值,则页面会仅展示返回值')");

需要H5支持:

test1Fun(str){this.test1Content = str;// return "调用test1Fun成功";}mounted(){window.test1Fun = this.test1Fun;}

这种方法比较简单,但是缺点在于android无法获取函数的返回值
注:如果调用的函数存在返回值的话,那么H5的页面会只显示返回值

  • 方法二:使用WebView的evaluateJavascript()方法

android方法:

mWebView.evaluateJavascript("test2Fun('使用这种方法可以取得返回参数,且不会刷新页面')", new ValueCallback<String>() {@Overridepublic void onReceiveValue(String value) {text2.setText(value);}});

这种方法同样需要H5支持,同上:

test2Fun(str){this.test2Content = str;return "调用test2Fun成功";}mounted(){window.test2Fun = this.test2Fun;}

这种方法比上一种方法更为灵活,且能够获取返回值

H5调用android

  • 方法一:使用WebView的addJavascriptInterface()方法注入对象。

android注入:

mWebView.addJavascriptInterface(new JsInteration(), "android");public class JsInteration {        @JavascriptInterface        public String JsCallJava1(String value) {            text3.setText(value);            return "调用JsCallJava1成功";        }    }

H5调用:

useJsCallJava1(){            let a = window.android.JsCallJava1("我是JsCallJava1的返回值");            this.JsCallJava1Content = a;        }

这种方式运用最为广泛,一些企业级的项目都是以此为基础搭建H5调用android的桥方法,当然,为了防止注入过多的方法,参数一般是JSON字符串格式,在android获取到参数后,会将其转换为JSON,然后根据其状态,进行后续的操作反馈。

  • 方法二:使用WebViewClient 的shouldOverrideUrlLoading()方法回调拦截请求。

android方法:

mWebView.setWebViewClient(new WebViewClient() {            @Override            public boolean shouldOverrideUrlLoading(WebView view, String url) {                if (url.equals("http://10.20.58.190:8081/intercept")) {                    text4.setText("intercept");//                    startActivity(new Intent(MainActivity.this,SecondFragment.class));                    return true;                } else {                    mWebView.loadUrl(url);                    return false;                }            }        });

H5调用:

location.href = "http://10.20.58.190:8081/intercept";

注:这里一般是用于拦截链接,如果shouldOverrideUrlLoading的返回值为true,则会进行拦截,H5不进行跳转,否则则进行跳转

  • 方法三:重写 WebChromeClient 的onJsAlert()、onJsConfirm()、onJsPrompt()方法回调拦截JS对话框alert()、confirm()、prompt() 消息。

android方法:

mWebView.setWebChromeClient(new WebChromeClient(){            @Override            public boolean onJsAlert(WebView view, String url, String message, JsResult result){                if (message.equals("alert")){                    alert.setText("成功");                }                return super.onJsAlert(view, url, message, result);            }            @Override            public boolean onJsConfirm(WebView view, String url, String message, JsResult result) {                if (message.equals("confirm")){                    confirm.setText("成功");                }                return super.onJsConfirm(view, url, message, result);            }            @Override            public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, JsPromptResult result) {                if (message.equals("prompt")){                    prompt.setText("成功");                }                return super.onJsPrompt(view, url, message, defaultValue, result);            }        });

H5触发:

useJsCallJava3(judge){            if(judge == 1){                alert('alert')            }            if(judge == 2){                confirm('confirm')            }            if(judge == 3){                prompt('prompt')            }        }

此方法将会监听三种弹窗,用户可以根据弹窗内容进行判断,但是请注意
如果在android拦截后,return了true,则会默认客户会对弹窗进行处理,所以我们要对弹窗进行额外处理,否则H5页面就会卡死。
因此这种方法为了避免麻烦,还是少用为好,并且不对弹窗进行拦截,仅监听即可。

最后,完整的demo如下

MainActivity.java:

package com.example.study_android_java_javascript;import android.os.Bundle;import android.view.View;import android.webkit.JavascriptInterface;import android.webkit.JsPromptResult;import android.webkit.JsResult;import android.webkit.ValueCallback;import android.webkit.WebChromeClient;import android.webkit.WebSettings;import android.webkit.WebView;import android.webkit.WebViewClient;import android.widget.Button;import android.widget.TextView;import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity {    public static final String TAG = "MainActivity";    private WebView mWebView;    private TextView text1;    private TextView text2;    private TextView text3;    private TextView text4;    private Button btn1;    private Button btn2;    private Button btn_clear;    private TextView alert;    private TextView confirm;    private TextView prompt;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        text1 =findViewById(R.id.text1);        text2 =findViewById(R.id.text2);        text3 = findViewById(R.id.text3);        text4 = findViewById(R.id.text4);        alert = findViewById(R.id.alert);        confirm = findViewById(R.id.confirm);        prompt = findViewById(R.id.prompt);        btn1 = (Button) findViewById(R.id.btn1);        btn1.setOnClickListener(new View.OnClickListener(){            @Override            public void onClick(View view) {                mWebView.loadUrl("javascript:test1Fun('使用这种方法无法取得返回参数,且会刷新页面,如果js函数有返回值,则页面会仅展示返回值')");            }        });        btn2 = (Button) findViewById(R.id.btn2);        btn2.setOnClickListener(new View.OnClickListener(){            @Override            public void onClick(View view) {                mWebView.evaluateJavascript("test2Fun('使用这种方法可以取得返回参数,且不会刷新页面')", new ValueCallback<String>() {                    @Override                    public void onReceiveValue(String value) {                        text2.setText(value);                    }                });            }        });        btn_clear = findViewById(R.id.btn_clear);        btn_clear.setOnClickListener(new View.OnClickListener(){            @Override            public void onClick(View view) {                mWebView.loadUrl("javascript:clearContent()");                text2.setText("暂无返回");            }        });        mWebView = (WebView) findViewById(R.id.webView);        mWebView.loadUrl("http://10.20.58.190:8081/");        WebSettings webSettings = mWebView.getSettings();        webSettings.setJavaScriptEnabled(true);        mWebView.addJavascriptInterface(new JsInteration(), "android");        mWebView.setWebViewClient(new WebViewClient() {            @Override            public boolean shouldOverrideUrlLoading(WebView view, String url) {                if (url.equals("http://10.20.58.190:8081/intercept")) {                    text4.setText("intercept");//                    startActivity(new Intent(MainActivity.this,SecondFragment.class));                    return true;                } else {                    mWebView.loadUrl(url);                    return false;                }            }        });        mWebView.setWebChromeClient(new WebChromeClient(){            @Override            public boolean onJsAlert(WebView view, String url, String message, JsResult result){                if (message.equals("alert")){                    alert.setText("成功");                }                return super.onJsAlert(view, url, message, result);            }            @Override            public boolean onJsConfirm(WebView view, String url, String message, JsResult result) {                if (message.equals("confirm")){                    confirm.setText("成功");                }                return super.onJsConfirm(view, url, message, result);            }            @Override            public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, JsPromptResult result) {                if (message.equals("prompt")){                    prompt.setText("成功");                }                return super.onJsPrompt(view, url, message, defaultValue, result);            }        });    }    //Android调用有返回值js方法    public class JsInteration {        @JavascriptInterface        public String JsCallJava1(String value) {            text3.setText(value);            return "调用JsCallJava1成功";        }    }}

activity_main.xml

<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"    android:gravity="center_horizontal">    <WebView        android:layout_width="match_parent"        android:layout_height="200dp"        android:id="@+id/webView"        />    <Button        android:id="@+id/btn1"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:textAllCaps="false"        android:text="使用webview.loadUrl()调用JavaScript方法"/>    <TextView        android:id="@+id/text1"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="暂无返回"/>    <TextView        android:layout_width="match_parent"        android:layout_height="20dp"/>    <Button        android:id="@+id/btn2"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:textAllCaps="false"        android:text="使用webview.evaluateJavascript()调用JS方法"/>    <TextView        android:id="@+id/text2"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="暂无返回"/>    <Button        android:id="@+id/btn_clear"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:textAllCaps="false"        android:text="清除H5的内容"        android:layout_marginTop="20dp"/>    <TextView        android:layout_marginTop="10dp"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="JavaScript调用Java方法:"/>    <TextView        android:id="@+id/text3"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_marginTop="5dp"        android:text="JsCallJava1返回值"/>    <TextView        android:layout_marginTop="10dp"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="拦截链接:"/>    <TextView        android:id="@+id/text4"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="拦截测试数据"/>    <TextView        android:layout_marginTop="10dp"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="拦截弹窗"/>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:orientation="horizontal"        android:gravity="center">        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text="alert:"/>        <TextView            android:id="@+id/alert"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text=""/>    LinearLayout>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:orientation="horizontal"        android:gravity="center">        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text="confirm:"/>        <TextView            android:id="@+id/confirm"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text=""/>    LinearLayout>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:orientation="horizontal"        android:gravity="center">        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text="prompt:"/>        <TextView            android:id="@+id/prompt"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text=""/>    LinearLayout>LinearLayout>

indexVue.vue

<template>    <div class="box">        <div class="test1">            <h3 title="123">{{test1}}</h3>            <h4>测试内容:{{test1Content}}</h4>        </div>        <div class="test2">            <h3>{{test2}}</h3>            <h4>测试内容:{{test2Content}}</h4>        </div>        <button @click="useJsCallJava1">调用Java方法:JsCallJava1</button>        <h4>返回数据:{{JsCallJava1Content}}</h4>        <button @click="useJsCallJava2">拦截链接</button>        <h4>   </h4>        <button @click="useJsCallJava3(1)">测试拦截alert</button>        <button @click="useJsCallJava3(2)">测试拦截confirm</button>        <button @click="useJsCallJava3(3)">测试拦截prompt</button>            </div></template><script>export default {    data(){        return {            test1:"Java使用webview.loadUrl()调用JavaScript方法",            test1Content:"",            test2:"Java使用webview.evaluateJavascript()调用JavaScript方法",            test2Content:"",            JsCallJava1Content:"",        };    },    methods:{        test1Fun(str){            this.test1Content = str;            // return "调用test1Fun成功";        },        test2Fun(str){            this.test2Content = str;            return "调用test2Fun成功";        },        clearContent(){            this.test1Content = "";            this.test2Content = "";        },        useJsCallJava1(){            let a = window.android.JsCallJava1("我是JsCallJava1的返回值");            this.JsCallJava1Content = a;        },        useJsCallJava2(){            location.href = "intercept";        },        useJsCallJava3(judge){            if(judge == 1){                alert('alert')            }            if(judge == 2){                confirm('confirm')            }            if(judge == 3){                prompt('prompt')            }        }    },    mounted(){        window.test1Fun = this.test1Fun;        window.test2Fun = this.test2Fun;        window.clearContent = this.clearContent;    }}</script><style scoped>    h3{        color: blue;    }    h4{        color: red;    }</style>

来源地址:https://blog.csdn.net/qq_44027159/article/details/127535628

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

关于原生android与H5交互的方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android实现H5与Native交互的两种方式

前言 大家都知道在Android WebView使用中,经常需要H5页面和Native页面进行交互,比如在网页上点击分享按钮,调用本地分享接口进行分享,分享成功后本地调用网页的JavaScript代码展示一条分享成功的消息。下面来看看一起看
2022-06-06

android与js交互的方法是什么

Android与JS交互的方法有多种,以下是其中一些常用的方法:1. 使用WebView:Android中的WebView组件可以加载显示网页,并且提供了与JS交互的方法。通过WebView的addJavascriptInterface()
2023-09-21

基于Android中手势交互的实现方法

闲来无事,琢磨琢磨Android中的手势交互,发现网上在手势方面的文章并不是很多,而且很多的参考价值并不大。于是出此博文,与大家共勉。鉴于我写此博文时对手势交互的研究也不是特深,如果有不正确的地方,还请各位博友批评指正。 首先,在Andro
2022-06-06

Android中WebView与Js交互的实现方法

获取WebView对象 调用WebView对象的getSettings()方法,获取WebSettings对象 调用WebSettings对象的setJavaScriptEnabled()方法,设置js可用,参数:布尔值 在判断是否支持js
2022-06-06

android与云服务器交互的方法是什么

Android与云服务器交互的方法可以通过以下几种方式:1. RESTful API:使用HTTP协议通过RESTful风格的API进行通信。Android应用可以通过HTTP请求发送数据到云服务器,服务器返回相应的结果。常用的HTTP客户
2023-09-26

android与云服务器交互的方法是什么

Android与云服务器交互的方法Android应用程序与云服务器交互的关键方法包括:HTTP/HTTPS:常见数据传输协议,可提供安全加密(HTTPS)。RESTfulAPI:统一云API接口,使用HTTP方法和JSON/XML表示。gRPC:高效的远程过程调用框架,提供二进制编码和解析。WebSocket:全双工持续连接协议,支持服务器推送实时更新。MQTT:轻量级消息传递协议,专用于物联网应用程序。Firebase:Google平台,提供简化云交互的服务。AWSSDK:AmazonWebServic
android与云服务器交互的方法是什么
2024-04-10

Android编程使用WebView实现与Javascript交互的方法【相互调用参数、传值】

本文实例讲述了Android编程使用WebView实现与Javascript交互的方法。分享给大家供大家参考,具体如下: Android中可以使用WebView加载网页,同时Android端的Java代码可以与网页上的JavaScript代
2022-06-06

Android React Native原生模块与JS模块通信的方法总结

Android React Native原生模块与JS模块通信的方法总结 前言: 在做React Native开发的时候避免不了的需要原生模块和JS之间进行数据传递,这篇文章将向大家分享原生模块向JS传递数据的几种方式。 方式一:通过Cal
2022-06-06

有关HikariPool-1 – Failed to validate connection com.mysql.cj.jdbc.ConnectionImp 错误的产生原因与解决方法

如果长时间静默没有数据库操作就报Failed to validate connection com.mysql.cj.jdbc.ConnectionImpl@72b70c61 (No operations allowed after con
2023-08-19

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录