日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

Android和JS之间互相调用方法并传递参数

發布時間:2025/3/19 Android 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android和JS之间互相调用方法并传递参数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

場景

Android中使用WebView加載本地html并支持運行JS代碼和支持縮放:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/118637633

在上面實現使用加載html顯示之后,怎樣進行互相調用方法和傳遞參數。

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi
關注公眾號
霸道的程序猿
獲取編程相關電子書、教程推送與免費下載。

實現

Android中調用JS方法

首先在Android中新增一個按鈕,并設置其點擊事件

??????? //Android中調用JS方法Button button = findViewById(R.id.button);button.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {callJs();}});

點擊事件中調用了callJs方法,然后再activity中實現該方法

??? @SuppressLint("SetJavaScriptEnabled")public void callJs(){webView.loadUrl("javascript:toAndroidCall()");}

然后在JS中實現該方法

??????? //Android中調用JS方法function toAndroidCall(){alert("Android中調用JS方法成功");}

效果

?

如果要傳遞參數可以

??? @SuppressLint("SetJavaScriptEnabled")public void callJs(){String message = "公眾號:霸道的程序猿";webView.loadUrl("javascript:toAndroidCallWithParam('"+message+"')");}

然后在JS端

??????? //Android中調用JS方法-帶參數function toAndroidCallWithParam(message){alert("Android中調用JS方法成功,收到參數:"+message);}

效果

?

JS中調用Android的方法

在Android中實現方法

??? //JS調用Android方法@JavascriptInterfacepublic void jsCallAndroid(){Toast.makeText(this,"JS調用Android方法成功",Toast.LENGTH_LONG).show();}

要加注解,然后還需要給webView進行配置

??????? //增加JS接口webView.addJavascriptInterface(this,"badao");

增加一個JS接口

然后在JS中新增一個按鈕

<button id="button" onclick="toCallAndroid()">JS調用Android方法</button>

并設置點擊事件

??????? //JS中調用Android方法function toCallAndroid(){badao.jsCallAndroid();}

效果

?

?

如果要傳遞參數

??? //JS調用Android方法-帶參數@JavascriptInterfacepublic void jsCallAndroidWithParam(String message){Toast.makeText(this,"JS調用Android方法成功,收到參數:"+message,Toast.LENGTH_LONG).show();}

在JS中

??????? //JS中調用Android方法function toCallAndroidWithParam(){badao.jsCallAndroidWithParam("霸道的程序猿");}

效果

?

MainActivity完整代碼

?

package com.badao.webviewdemo;import androidx.appcompat.app.AppCompatActivity;import android.annotation.SuppressLint; import android.os.Bundle; import android.view.View; import android.webkit.JavascriptInterface; import android.webkit.WebChromeClient; import android.webkit.WebView; import android.widget.Button; import android.widget.Toast;public class MainActivity extends AppCompatActivity {WebView webView = null;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);//獲取webviewwebView = findViewById(R.id.webview);//設置為ChromeClinet 才能執行js代碼WebChromeClient webChromeClient = new WebChromeClient();webView.setWebChromeClient(webChromeClient);//設置開啟js支持webView.getSettings().setJavaScriptEnabled(true);// 是否支持縮放webView.getSettings().setSupportZoom(true);//加載本地html//webView.loadUrl("file:///android_asset/offLineTileMap.html");webView.loadUrl("file:///android_asset/demo.html");//Android中調用JS方法Button button = findViewById(R.id.button);button.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {callJs();}});//增加JS接口webView.addJavascriptInterface(this,"badao");}@SuppressLint("SetJavaScriptEnabled")public void callJs(){//webView.loadUrl("javascript:toAndroidCall()");String message = "公眾號:霸道的程序猿";webView.loadUrl("javascript:toAndroidCallWithParam('"+message+"')");}//JS調用Android方法@JavascriptInterfacepublic void jsCallAndroid(){Toast.makeText(this,"JS調用Android方法成功",Toast.LENGTH_LONG).show();}//JS調用Android方法-帶參數@JavascriptInterfacepublic void jsCallAndroidWithParam(String message){Toast.makeText(this,"JS調用Android方法成功,收到參數:"+message,Toast.LENGTH_LONG).show();} }

總結

以上是生活随笔為你收集整理的Android和JS之间互相调用方法并传递参数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。