0
点赞
收藏
分享

微信扫一扫

Android与H5(JavaScript)之间的简单交互


Android响应Js的动作 

假设网页端要调用Android原生的方法:showToast();

1.做一个盆子接收消息(创建一个工具类,写一个方法(*带注解))

public class JavaScriptMethod {

//相当于一个匹配标识
public static final String JAVAINTERFACE = "javaInterface";
//上下文拿过来 方便后续操作
private Context mContext;
private WebView mWebView;

public JavaScriptMethod(Context context, WebView webView) {
mContext = context;
mWebView = webView;
}

//andorid4.2(包括android4.2)以上,如果不写该注解,js无法调用android方法
@JavascriptInterface
public void showToast(String json) {
Bean_JS bean = new Gson().fromJson(json, Bean_JS.class);
}
}

2.给你的WebView加个属性

// 支持JavaScript
mWebView.getSettings().setJavaScriptEnabled(true);

3.继续,把下面的这些粘贴到下面

//创建上面创建类的对象
JavaScriptMethod m = new JavaScriptMethod(getActivity(), mWebView);
//其实就是告诉js,我提供给哪个对象给你调用,这样js就可以调用对象里面的方法
//第二个参数就是该类中的字符串常量
mWebView.addJavascriptInterface(m, JavaScriptMethod.JAVAINTERFACE);

4. 好了Android做完前3步就结束了

把下面的代码写到H5端JS代码的事件(点击/滑动)中

//参数一般为json格式    
var json = {"name":"javascript"};
//javaInterface是上面所说的字符串映射对象
window.javaInterface.showToast(JSON.stringify(json));

Android调用Js的方法

假设Android要调用网页端的Js方法: Text()

if (Build.VERSION.SDK_INT < 18) {
mWebView.loadUrl("javascript:Text()");
} else {
mWebView.evaluateJavascript("javascript:Text()", new ValueCallback<String>() {
@Override
public void onReceiveValue(String value) {
//此处为 js 返回的结果
}
});
}
//假如方法有参数,int类型这么写:
int i= 0;
"javascript:Text("+i+")"
//假如方法有参数,String 类型这么写:!!切记参数前后 要拼单引号
String s= "啦啦啦";
"javascript:Text('"+s+"')"

举报

相关推荐

0 条评论