这个 刚开始 我也不会,把我整的是个蛋疼的啊,
最后发现其实挺简单的,我现在给大家说的是我自己掌握的一种,
1. 先是要给项目配置一些权限
(1)、访问网络权限
(2)、访问SD卡权限
2.给webview 配置
webView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
webView.getSettings().setBuiltInZoomControls(true);
webView.getSettings().setJavaScriptEnabled(true);
3.这个就是webview想JS 暴露一个 可以调用的对象(用来JS调用JAVA方法和JAVA调用JS又返回值的方法时用,如果非上面的两种情况时,则可以忽略此步。)
webView.addJavascriptInterface(new JsToJava(), "android"); //JsToJava是内部类,代码在后面。android 是接口名字。
上面的是准备工作
下面的就是要调用的代码了
java调用JS 方法(无返回值)
webView.loadUrl("javascript:getStsmA()");//调用 JS 中的方法
没错,你没有看错,就是这么简单,在加载完HTML页面后,执行这段代码,就可以调用JS 中的方法了
JS调用java
webView.addJavascriptInterface(new JsToJava(), "android"); //JsToJava是内部类,代码在后面。android 是接口名字。
webView.loadUrl("javascript:getStsmA()");//调用JS中的方法
private class JsToJava {
@JavascriptInterface
public void getStsm(String paramFromJS) {//java暴露的方法,用于 JS 调用
Log.e(TAG, "js返回结果===" + paramFromJS);//处理返回的结果
}
}
我在贴出来JS 代码
大家要注意了最后一段代码
window.android.getStsm(rtn) ;
这段代码的意思是JS调用JAVA中的方法
android:java中想JS 中暴露的对象名
getStsm:用Java中暴露的对象名。方法名(就是调用java中的getStsm()这个方法)
这样JS 就可以通过java这边暴露的对象名和方法名调用
大家要输还是不理解的话,就看看 这张图吧!!!
好了 给大家上代码 吧
import android.annotation.SuppressLint;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
import android.webkit.JavascriptInterface;
import android.webkit.WebView;
import android.widget.Button;
public class MainActivity extends AppCompatActivity {
private WebView webView;
private static final String TAG = "MainActivity";
private Button but;
@SuppressLint("JavascriptInterface")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = (WebView) this.findViewById(R.id.webView_viewTable);
but = (Button) this.findViewById(R.id.but);
/**
*在Android中要 用java调用 JS 很简单 直接
*webView.loadUrl("javascript:getfsA()");//调用 JS 中的方法
*这个就是调用无返回值的 方式,直接一句话 (当然 对webview 还有一些 配置,在这里 先 不说了)
* 传参数给webview 的话 ,就是在
* webView.loadUrl("javascript:getfsA('参数')");//调用 JS 中的方法
* 就是上面的方法
* 这样 我们的 java 调用 JS 的无返回值 方法 ,就完了
*
* 要调用又返回值的话,我们这边不是接收者,而是我们调用JS 中的方法,
* 让此方法调用 本地的 一个java方法,然后 传值过来,这样 我们就接收到值了
* */
//这几行代码是对webview的授权,不能少
webView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
webView.getSettings().setBuiltInZoomControls(true);
webView.getSettings().setJavaScriptEnabled(true);
webView.addJavascriptInterface(new JsToJava(), "android"); //JsToJava是内部类,代码在后面。android 是接口名字。
/** 这里的 第二个参数 就是 JS 回调 java的 一个方法名大家注意看下html文件中 调用的方法的返回
window.android.getfs(rtn);//JS 中 的代码,这句代码的意思是,通过android这个java暴露的借口,调用getfs()这个方法
*
**/
webView.loadUrl("file:///storage/emulated/0/1.html");//这句是载入一个html页面。
but.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
webView.loadUrl("javascript:getfsA()");//调用 JS 中的方法
}
});
}
private class JsToJava {
@JavascriptInterface
public void getfs(String paramFromJS) {//Android暴露的方法,用于 JS 调用
//这个方法就是JS 调用java方法 ,传回 返回值,这样我们就接收到JS 返回给我们的值了
Log.e(TAG, "js返回结果===" + paramFromJS);//处理返回的结果
}
}
}
下面的是html 代码
function getStsmA() {
var rtn = getStsm();
window.android.getStsm(rtn) ; }