Android五分钟轻松教会你掌握WebView与JS交互

    xiaoxiao2021-04-15  281

    背景:Android API中提供了WebView组件来实现对html的渲染。现在HTML5、CSS3、jS的相关开发技术,以及数据交换格式json/XML。Web开发工程师的技能。为了减少对android的过度依赖,通常会在原生的Android 嵌入部分的html了。

    这样一来就避免不了为js数据交互。

    我们新建一个简单的布局,只有一个webview控件

    <android:id="@+id/webView" android:layout_width="fill_parent" android:layout_height="wrap_content" /> 

    我们找到这个webView,并加上载本地的main.html,其中main.html存储在工程文件的assets根目录下。

    WebView webView = (WebView) findViewById(R.id.webView); webView.addJavascriptInterface(newJSObject(context), "aikaifa"); WebSettings webSettings = webView.getSettings(); webSettings.setJavaScriptEnabled(true);// 支持js Handler handler = new Handler(); handler.postDelayed(new Runnable() { public void run() { webView.loadUrl("file:///android_asset/main.html"); }, 500); 

    1.js调用Android方法

    细心的你应该会注意到上面有个JSObject类,没错,就是这个开启了入口,前端js 才可以调用我们Android这边写的方法。其中的“aikaifa” 可以理解成一个标示,可以随便改成你喜欢的。

    我们来看一下JSObject这个类:

    public class JSObject {  private Context context;  public JSObject(Context context){  this.context=context; @JavascriptInterface  public void goBack({  Activity activity = (Activity) context;  activity.finish();  } 

    该类定义了goBack方法,注入JS可以调用。

    js如果想要调用goBack这个方法。可以这个aikaifa.goBack() 这样调用即可。

    这样前端就可以很方便调用我们Android这边的方法了。

    2.Android调用JS方法

    既然js可以调用我们的方法,那我们同样也调用js方法

    例如我们想调用js 中getName方法。

    我们可以这样写。

    public void getTestJS()    Timertimer = new Timer();    final Handler handler = new Handler(){    public void handleMessage(Message msg) {        switch (msg.what) {           case 1:          webView.loadUrl("javascript:getName()");          break;     }    super.handleMessage(msg);   } };    timer.schedule(new TimerTask() {    public void run() {             Message msg = new Message();             msg.what = 1;              handler.sendMessage(msg);        }     }, 500, 500); 

    其中getName方法是js中的一个方法,我们可以在需要的地方调用getTestJS方法就可以了。

    这样WebView与js交互就大致完成了。

    作者:洪生鹏 来源:51CTO 相关资源:七夕情人节表白HTML源码(两款)

    最新回复(0)