Android五分钟轻松教会你掌握WebView与JS交互
背景: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); }
相关推荐
zengdaquan00 2014-03-20
zmmzmm 2016-01-04
xuesong 2019-06-30
dangai00 2020-07-18
xhpscdx 2020-05-31
chenxiangpeng 2020-04-30
ncuboy0wsq 2020-03-27
学习web前端 2020-03-23
APCDE 2020-03-04
歆萌 2020-03-03
csdnuuu 2020-01-04
水龙吟的备忘录 2019-11-18
icewizardry 2014-04-10
元元 2019-11-17
androidstudyroom 2019-11-08
czpaex 2011-09-11