Android webview与js交互

Android webview与js交互

布局

<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);
Handler handler = new Handler();
handler.postDelayed(new Runnable() {
public void run() {
webView.loadUrl("file:///android_asset/main.html");
}
}, 500);

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这边的方法了。

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交互就大致完成了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值