h5传递数据php接收,webview和h5数据传递

webview的简单加载

webView.loadUrl("https://www.baidu.com/");

加载前需要设置一些属性,如:

WebSettings webSettings = webView.getSettings();

webSettings.setDomStorageEnabled(true); //保存数据

webSettings.setJavaScriptEnabled(true); //启用js

webSettings.setBlockNetworkImage(false); //解决图片不显示

webSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口

webSettings.setLoadsImagesAutomatically(true); //支持自动加载图片

h5获取Android数据

webView.addJavascriptInterface(new JSInterface(),"eBookJsInterface");

其中JSInterface()为内部类

public class JSInterface{

@SuppressLint("JavascriptInterface")

@JavascriptInterface

public boolean viewRegulationChanged(){

return isViewRegulation;

}

@JavascriptInterface

public boolean opeRegulationChanged(){

return isOpeRegulation;

}

}

js可以调用其中函数,从而获取到内部数据。

Android向h5主动发送数据

找到一个好用的方法,可以不用刷新界面,调用js端函数。

webView.evaluateJavascript("javascript:viewRegulationChanged()", new ValueCallback() {

@Override

public void onReceiveValue(String value) {

//此处为 js 返回的结果

Log.i(TAG, "onReceiveValue: sendRegulationToJs success");

}

});

其中javascript:viewRegulationChanged()为js端函数名,调用成功后,会输出onReceiveValue中的log。

需要注意的是,如果报错:All WebView methods must be called on the same thread.

则需要切换线程即:

webView.post(new Runnable() {

@Override

public void run() {

webView.evaluateJavascript("javascript:viewRegulationChanged()", new ValueCallback() {

@Override

public void onReceiveValue(String value) {

//此处为 js 返回的结果

Log.i(TAG, "onReceiveValue: sendRegulationToJs success");

}

});

}

});

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值