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

移动开发 Android
Android API中提供了WebView组件来实现对html的渲染。现在HTML5、CSS3、jS的相关开发技术,以及数据交换格式json/XML。Web开发工程师的技能。

[[189497]]

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

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

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

  1. <android:id="@+id/webView" 
  2. android:layout_width="fill_parent" 
  3. android:layout_height="wrap_content" 
  4. /> 

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

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

1.js调用Android方法

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

我们来看一下JSObject这个类:

  1. public class JSObject { 
  2.  private Context context; 
  3.  public JSObject(Context context){ 
  4.  this.context=context; 
  5. @JavascriptInterface 
  6.  public void goBack({ 
  7.  Activity activity = (Activity) context; 
  8.  activity.finish(); 
  9.  } 

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

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

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

2.Android调用JS方法

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

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

我们可以这样写。

  1. public void getTestJS() 
  2.    Timertimer = new Timer(); 
  3.    final Handler handler = new Handler(){ 
  4.    public void handleMessage(Message msg) { 
  5.        switch (msg.what) { 
  6.           case 1: 
  7.          webView.loadUrl("javascript:getName()"); 
  8.          break; 
  9.     } 
  10.    super.handleMessage(msg); 
  11.   } 
  12. }; 
  13.    timer.schedule(new TimerTask() { 
  14.    public void run() { 
  15.             Message msg = new Message(); 
  16.             msg.what = 1; 
  17.              handler.sendMessage(msg); 
  18.        } 
  19.     }, 500, 500); 

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

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

【本文为51CTO专栏作者“洪生鹏”的原创稿件,转载请联系原作者】

戳这里,看该作者更多好文

责任编辑:武晓燕 来源: 51CTO专栏
相关推荐

2022-03-18 15:41:29

原子化服务HarmonyOS鸿蒙

2021-04-23 09:50:41

topLinux命令

2009-11-25 09:02:12

2021-06-07 09:51:22

原型模式序列化

2009-11-17 14:50:50

Oracle调优

2024-03-21 09:51:22

Python爬虫浏览网站

2009-11-05 10:55:22

Visual Stud

2021-01-11 09:33:37

Maven数目项目

2023-12-06 08:48:36

Kubernetes组件

2017-01-10 09:07:53

tcpdumpGET请求

2011-06-12 18:30:07

投影机技巧

2021-01-13 09:23:23

优先队列React二叉堆

2018-01-08 16:19:04

微信程序轮播图

2024-08-07 10:16:00

2024-09-03 09:47:09

闭包装饰器Python

2022-03-08 08:39:22

gRPC协议云原生

2009-11-05 10:56:31

WCF通讯

2023-02-26 23:47:40

2015-12-03 14:10:26

systemd容器Linux

2021-10-20 06:58:10

工具低代码无代码
点赞
收藏

51CTO技术栈公众号