自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Android五分鐘輕松教會(huì)你掌握WebView與JS交互

移動(dòng)開(kāi)發(fā) Android
Android API中提供了WebView組件來(lái)實(shí)現(xiàn)對(duì)html的渲染?,F(xiàn)在HTML5、CSS3、jS的相關(guān)開(kāi)發(fā)技術(shù),以及數(shù)據(jù)交換格式j(luò)son/XML。Web開(kāi)發(fā)工程師的技能。

[[189497]]

背景:Android API中提供了WebView組件來(lái)實(shí)現(xiàn)對(duì)html的渲染?,F(xiàn)在HTML5、CSS3、jS的相關(guān)開(kāi)發(fā)技術(shù),以及數(shù)據(jù)交換格式j(luò)son/XML。Web開(kāi)發(fā)工程師的技能。為了減少對(duì)android的過(guò)度依賴,通常會(huì)在原生的Android 嵌入部分的html了。

這樣一來(lái)就避免不了為js數(shù)據(jù)交互。

我們新建一個(gè)簡(jiǎn)單的布局,只有一個(gè)webview控件

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

我們找到這個(gè)webView,并加上載本地的main.html,其中main.html存儲(chǔ)在工程文件的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調(diào)用Android方法

細(xì)心的你應(yīng)該會(huì)注意到上面有個(gè)JSObject類,沒(méi)錯(cuò),就是這個(gè)開(kāi)啟了入口,前端js 才可以調(diào)用我們Android這邊寫(xiě)的方法。其中的“aikaifa” 可以理解成一個(gè)標(biāo)示,可以隨便改成你喜歡的。

我們來(lái)看一下JSObject這個(gè)類:

  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可以調(diào)用。

js如果想要調(diào)用goBack這個(gè)方法??梢赃@個(gè)aikaifa.goBack() 這樣調(diào)用即可。

這樣前端就可以很方便調(diào)用我們Android這邊的方法了。

2.Android調(diào)用JS方法

既然js可以調(diào)用我們的方法,那我們同樣也調(diào)用js方法

例如我們想調(diào)用js 中g(shù)etName方法。

我們可以這樣寫(xiě)。

  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); 

其中g(shù)etName方法是js中的一個(gè)方法,我們可以在需要的地方調(diào)用getTestJS方法就可以了。

這樣WebView與js交互就大致完成了。

【本文為51CTO專欄作者“洪生鵬”的原創(chuàng)稿件,轉(zhuǎn)載請(qǐng)聯(lián)系原作者】

戳這里,看該作者更多好文

責(zé)任編輯:武曉燕 來(lái)源: 51CTO專欄
相關(guān)推薦

2022-03-18 15:41:29

原子化服務(wù)HarmonyOS鴻蒙

2021-04-23 09:50:41

topLinux命令

2009-11-25 09:02:12

2009-11-17 14:50:50

Oracle調(diào)優(yōu)

2021-06-07 09:51:22

原型模式序列化

2024-03-21 09:51:22

Python爬蟲(chóng)瀏覽網(wǎng)站

2025-01-24 08:38:47

2021-01-11 09:33:37

Maven數(shù)目項(xiàng)目

2009-11-05 10:55:22

Visual Stud

2023-12-06 08:48:36

Kubernetes組件

2017-01-10 09:07:53

tcpdumpGET請(qǐng)求

2011-06-12 18:30:07

投影機(jī)技巧

2018-01-08 16:19:04

微信程序輪播圖

2021-01-13 09:23:23

優(yōu)先隊(duì)列React二叉堆

2024-08-07 10:16:00

2024-09-03 09:47:09

閉包裝飾器Python

2022-03-08 08:39:22

gRPC協(xié)議云原生

2009-11-05 10:56:31

WCF通訊

2024-12-25 12:00:00

C++解包代碼

2023-02-26 23:47:40

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)