JsBridge
SDK支持
- Js调用原生方法并支持异步回调和同步回调
- 原生调用Js方法并支持异步回调
- Js调用名称空间可自由配置,统一管理命名空间
- 支持Js调用原生方法多次回调,如果不想多次回调可以删除回调方法
- 支持部分Js框架中window并非顶级window
API介绍
-
callJsFunction(function: String)
原生调用Js的方法,不支持传递参数和回调
参数
- function:调用Js的方法名称
-
callJsFunction(function: String, callback: JsCallback?)
原生调用Js的方法,不支持传递参数但支持回调
参数
- function:调用Js的方法名称
- callback:回调函数
-
callJsFunction(function: String, data: String?)
原生调用Js的方法,支持传递参数,但不支持回调
参数
- function:调用Js的方法名称
- data:字符串,传递给Js的参数
-
callJsFunction(function: String, data: String?, callback: JsCallback?)
原生调用Js的方法,支持传递参数和回调
参数
- function:调用Js的方法名称
- data:字符串,传递给Js的参数
- callback:回调函数
-
jsCallName()
Js调用原生的API命名空间,SDK统一了命名空间,默认为
JsBridge
,整个Js调用中只会使用这个命名,当然,如果是你不喜欢这个命名,或者需要根据项目更改为项目有关的命名,可以自定义WebView继承至BaseWebView重写该方法。 -
getWindow()
Js中获取window的方法,建议不要随意修改。在特殊的Js框架中,获取系统的window需要window.window才能获取到,所以这时候可以自定义WebView继承至BaseWebView重写该方法。
如何使用
依赖引入
Step 1.先在 build.gradle(Project:XXX) 的 repositories 添加:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
Step 2. 然后在 build.gradle(Module:XXX) 的 dependencies 添加:
dependencies {
implementation 'com.github.ChinaLike:JsBridge:0.0.2'
}
JsBridgeToast
新建Js调用原生方法的类,参考:package com.like.jsbridge
import android.content.Context
import android.os.Handler
import android.util.Log
import android.webkit.JavascriptInterface
import android.widget.Toast
import com.core.web.Callback
import com.core.web.CallbackBean
class JsBridgeToast(private val context: Context) {
@JavascriptInterface
fun nativeNoArgAndNoCallback(){
Toast.makeText(context,"调用原生无参数无回调方法",Toast.LENGTH_SHORT).show()
}
@JavascriptInterface
fun nativeNoArgAndCallback(callback: Callback){
callback.success()
}
@JavascriptInterface
fun nativeArgAndNoCallback(params:String){
Toast.makeText(context,params,Toast.LENGTH_SHORT).show()
}
@JavascriptInterface
fun nativeArgAndCallback(params:String,callback: Callback):Boolean{
Toast.makeText(context,params,Toast.LENGTH_SHORT).show()
callback.success()
return false
}
@JavascriptInterface
fun nativeDeleteCallback(params:String,callback: Callback){
Toast.makeText(context,params,Toast.LENGTH_SHORT).show()
callback.success(isDelete = true)
Handler().postDelayed(Runnable {
callback.error(1,"错误回调")
},3000)
}
@JavascriptInterface
fun nativeNoDeleteCallback(params:String,callback: Callback){
Toast.makeText(context,params,Toast.LENGTH_SHORT).show()
callback.success(isDelete = false)
Handler().postDelayed(Runnable {
callback.error(1,"错误回调")
},3000)
}
@JavascriptInterface
fun nativeSyncCallback():String{
return "原生同步回调"
}
}
MainActivityKotlin和activity_main
新建MainActivity和xml文件,参考:- 在xml文件中引入JsBridgeWebView
<com.core.web.JsBridgeWebView android:id="@+id/webView" android:layout_width="match_parent" android:layout_height="match_parent"/>