android與js的交互之jsbridge使用

来源:https://www.cnblogs.com/taixiang/archive/2018/05/20/9062871.html
-Advertisement-
Play Games

眾所周知,app的一些功能可能會使用到H5開發,這就難免會遇到java與js 的相互調用,android 利用WebViewJavascriptBridge 實現js和java的交互,這裡介紹下JsBridge第三方庫的使用。 github傳送門:https://github.com/lzyzsd/ ...


眾所周知,app的一些功能可能會使用到H5開發,這就難免會遇到java與js 的相互調用,android 利用WebViewJavascriptBridge 實現js和java的交互,這裡介紹下JsBridge第三方庫的使用。
github傳送門:https://github.com/lzyzsd/JsBridge

簡單分析

java與js相互調用如下:
java發送數據給js,js接收並回傳給java
同理,js發送數據給java,java接收並回傳給js
同時兩套流程都存在「預設接收」 與 「指定接收」
大致調用流程圖如下:

依賴

項目build.gradle

repositories {
    // ...
    maven { url "https://jitpack.io" }
}

app build.gradle

dependencies {
    compile 'com.github.lzyzsd:jsbridge:1.0.4'
}

xml里直接使用com.github.lzyzsd.jsbridge.BridgeWebView替代原生WebView
另外放置兩個Button用於測試使用

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <Button
        android:id="@+id/java_to_js_default"
        android:layout_width="180dp"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:text="java發送給js預設接收"
        app:layout_constraintTop_toBottomOf="@+id/nav_bar" />

    <Button
        android:id="@+id/java_to_js_spec"
        android:layout_width="180dp"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:text="java發送給js指定接收"
        app:layout_constraintTop_toBottomOf="@+id/java_to_js_default" />

    <com.github.lzyzsd.jsbridge.BridgeWebView
        android:id="@+id/webView"
        android:layout_width="0dp"
        android:layout_height="0dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/java_to_js_spec" />

</android.support.constraint.ConstraintLayout>

html文件里簡單放置兩按鈕發送數據,同時提供列印信息

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div>
    <button onClick="jsToJavaDefault()">js發送給java預設接收</button>
</div>
<br/>
<div>
    <button onClick="jsToJavaSpec()">js發送給java指定接收</button>
</div>
<br/>
<div id="show">列印信息</div>
</body>
</html>

這裡我本地跑的一個簡單的django項目,起了個服務供使用

webView.loadUrl("http://10.0.0.142:8000/cake/jsbridge");

webview載入頁面

java發送數據給js

button註冊監聽

javaToJsDefault.setOnClickListener(this);
javaToJsSpec.setOnClickListener(this);

按鈕點擊事件,java傳遞數據給js

    //java傳遞數據給js
    @Override
    public void onClick(View v) {
        switch (v.getId()) {
            case R.id.java_to_js_default:
                //預設接收
                webView.send("發送數據給js預設接收", new CallBackFunction() {
                    @Override
                    public void onCallBack(String data) { //處理js回傳的數據
                        Toast.makeText(WebTestActivity.this, data, Toast.LENGTH_LONG).show();
                    }
                });
                break;
            case R.id.java_to_js_spec:
                //指定接收參數 functionInJs
                webView.callHandler("functionInJs", "發送數據給js指定接收", new CallBackFunction() {
                    @Override
                    public void onCallBack(String data) { //處理js回傳的數據
                        Toast.makeText(WebTestActivity.this, data, Toast.LENGTH_LONG).show();
                    }
                });
                break;
            default:
                break;
        }
    }

js WebViewJavascriptBridge註冊事件監聽,接收數據


<script>

       //註冊事件監聽,初始化
       function setupWebViewJavascriptBridge(callback) {
           if (window.WebViewJavascriptBridge) {
               callback(WebViewJavascriptBridge)
           } else {
               document.addEventListener(
                   'WebViewJavascriptBridgeReady'
                   , function() {
                       callback(WebViewJavascriptBridge)
                   },
                   false
               );
           }
       }

       //回調函數,接收java發送來的數據
       setupWebViewJavascriptBridge(function(bridge) {
           //預設接收
           bridge.init(function(message, responseCallback) {
               document.getElementById("show").innerHTML = '預設接收到Java的數據: ' + message;

               var responseData = 'js預設接收完畢,並回傳數據給java';
               responseCallback(responseData); //回傳數據給java
           });

           //指定接收,參數functionInJs 與java保持一致
           bridge.registerHandler("functionInJs", function(data, responseCallback) {
               document.getElementById("show").innerHTML = '指定接收到Java的數據: ' + data;

               var responseData = 'js指定接收完畢,並回傳數據給java';
               responseCallback(responseData); //回傳數據給java
           });
       })
       
<script>

java發送給js預設接收

java發送給js指定接收

js發送數據給java

js按鈕點擊事件, 同時需要上面WebViewJavascriptBridge的註冊監聽回調函數

    //js傳遞數據給java
    function jsToJavaDefault() {
       var data = '發送數據給java預設接收';
       window.WebViewJavascriptBridge.send(
           data
           , function(responseData) { //處理java回傳的數據
              document.getElementById("show").innerHTML = responseData;
           }
       );
   }

   function jsToJavaSpec() {
       var data='發送數據給java指定接收';
       window.WebViewJavascriptBridge.callHandler(
           'submitFromWeb' //指定接收參數 submitFromWeb與java一致
           ,data
           , function(responseData) { //處理java回傳的數據
              document.getElementById("show").innerHTML = responseData;
           }
       );
   }

java 監聽接收數據

        //預設接收
        webView.setDefaultHandler(new BridgeHandler() {
            @Override
            public void handler(String data, CallBackFunction function) {
                String msg = "預設接收到js的數據:" + data;
                Toast.makeText(WebTestActivity.this, msg, Toast.LENGTH_LONG).show();

                function.onCallBack("java預設接收完畢,並回傳數據給js"); //回傳數據給js
            }
        });
        //指定接收 submitFromWeb 與js保持一致
        webView.registerHandler("submitFromWeb", new BridgeHandler() {
            @Override
            public void handler(String data, CallBackFunction function) {
                String msg = "指定接收到js的數據:" + data;
                Toast.makeText(WebTestActivity.this, msg, Toast.LENGTH_LONG).show();

                function.onCallBack("java指定接收完畢,並回傳數據給js"); //回傳數據給js
            }
        });

js發送給java預設接收

js發送給java指定接收

至此,jsBridge的使用流程完畢。
歡迎關註我的博客:https://blog.manjiexiang.cn/
歡迎關註微信公眾號
image.png


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 作者的電腦是10.13.3,些許配置偏差請自行略過 本文是學習探討途徑,請勿濫用,後果自負 MySQL8.0 篇章 官網http://www.mysql.com/downloads/ 下載即可,無需激活 這裡只講配置: 1、下載後找到mysql的bin目錄,(mac系統中會自動生成別名,) mysq ...
  • 《採桑子·重陽》 人生易老天難老,歲歲重陽。 今又重陽,戰地黃花分外香。 一年一度秋風勁,不似春光, 勝似春光,寥廓江天萬里霜 視圖:是存儲在資料庫中的查詢的SQL 語句,它主要出於兩種原因:安全原因, 視圖可以隱藏一些數據,如:社會保險基金錶,可以用視圖只顯示姓名,地址,而不顯示社會保險號和工資數 ...
  • 第一題 某班學生和考試成績信息如下表Student所示: Student表 ID SName Mark 1 Jack 90 2 Marry 96 3 Rose 88 4 Bob 86 5 John 83 6 Belty 85 7 Robert 其中ID為學生的編號,SName為姓名,Mark為成績, ...
  • 二台sql伺服器配置ISCSI虛擬磁碟 在上篇我們利用ISCSI Target軟體在DC-ISCSCI上創建了三個ISCSI虛擬磁碟,在下麵我們將為大家介紹SQL-CL01(hsr1 50)和SQL-CL02(hsr2 51)如何訪問這些ISCSI虛擬磁碟. SQL-CL01和SQL-CL02可以使 ...
  • 系統資料庫: 1、master:用於記錄所有SQL server系統級別的信息,比如說登錄的信息,系統設置信息。如果他沒了。你的SQL server就掛了。 2、model:模型的意思,就像模板一樣。創建資料庫都是繼承model。如果你在該資料庫下創建一張表,以後每創建新資料庫,就已經有了model ...
  • 虛擬磁碟創建 前面我們已經搭了域和兩台sql 伺服器, 下麵我們準備讓DC域伺服器除了擔當域控制器外,還行使另一個職能:充當集群共用存儲。 集群共用存儲是由群集內的每個節點都能共同訪問的一個存儲設備,本次實驗中準備用DC伺服器來模擬存儲設備。 第一步下載iscsi target程式, 放在dc 桌面 ...
  • 遍歷一個目錄下的所有文件 首先我們獲取用戶文檔目錄路徑 1 let manager = FileManager.default 2 let urlForDocument = manager.urls(for: .documentDirectory, in:.userDomainMask) 3 let ...
  • 枚舉、結構體和協議組成Model 1 //定義一個協議 2 protocol BaseItemProtocal { 3 var title: String { get set } //屬性是可讀可寫的 4 var type: CriteriaType { get set } 5 } 6 7 stru ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...