成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Android Web App官方文檔翻譯第三章:WebView構建應用

移動開發 Android
本文來自谷歌Android官方的Web App開發指導手冊的第三篇——WebView構建應用:在你的Android應用布局中使用WebView來展現web頁面,你可以創建從Javascript到客戶端Android代碼的接口。

文檔內容

將 WebView 加入你的應用

¨     在Webview中使用 JavaScript

¨     啟用 JavaScript

¨     將 JavaScript代碼綁定到Android代碼

處理頁面導航

¨    歷史記錄導航

關鍵的類

WebView

WebSettings

WebViewClient

相關手冊

Web View

如果你想發布一個web app(或者僅僅是一個web頁面)作為客戶端的一部分,你可以使用WebView。WebView是Android中 View的擴展,能讓你將web頁面作為你的活動布局(activity layout)。它不包含一個瀏覽器的完整功能,比如導航控制或者地址欄。 WebView默認做的僅僅是展現一個Web頁面。

使用 WebView的一個常見場景是當你想要在應用中提供一些你可能需要更新的信息的時候,比如終端用戶協議或者用戶指南。在你的Android應用中,你需要創建包含WebView的Activity ,然后利用它來展現你掛在網上的文檔。

另外一個使用WebView的場景是你為用戶提供的數據時需要連接網絡來獲取數據,比如email。在這種情況下,你可能會發現在Android應用中構建一個WebView來展現提供相關數據的web頁面更為容易,而不是試圖連接到網絡獲取數據,解析數據并將其安置到Android布局中。你可以設計一個專供Android設備使用的web頁面,并在Android中實現一個WebView來加載這個頁面。

該文檔展示了你可以如何開始使用 WebView并額外做一些事情,比如頁面導航、將web頁面中的Javascript代碼綁定到你的Android應用中的代碼上去。

將 WebView 加入你的應用

要在你的應用中加入WebView ,只需要在你的活動布局中加入元素即可。例如,下面是一個布局文件,在這個文件中,WebView 占滿了屏幕。

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <WebView  xmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:id="@+id/webview" 
  4.     android:layout_width="fill_parent" 
  5.     android:layout_height="fill_parent" 
  6. /> 

要在 WebView加載頁面, 使用 loadUrl()。例如:

  1. WebView myWebView = (WebView) findViewById(R.id.webview); 
  2. myWebView.loadUrl("http://www.example.com"); 

在它有效工作之前,你要保證你的應用能訪問網絡。要訪問網絡,需要在你的配置文件中獲取INTERNET許可。例如:

  1. <manifest ... > 
  2.     <uses-permission android:name="android.permission.INTERNET" /> 
  3.     ... 
  4. </manifest> 

 

這就是你要應用一個WebView 來展現web頁面基本的所要做的所有事情了。

在WebView中使用JavaScript

如果你想要你加載在WebView中的web頁面使用Javascript,你需要在WebView中啟用Javascript。一旦啟用Javascript,你就可以在你的應用代碼以及你的Javascript代碼間創建接口了。

啟用JavaScript

你可以通過WebView中帶有的 WebSettings來啟用它。你可以通過 getSettings()來獲取 WebSettings的值,然后通過setJavaScriptEnabled()來啟用JavaScript。

例如:

  1. WebView myWebView = (WebView) findViewById(R.id.webview);  
  2. WebSettings webSettings = myWebView.getSettings();  
  3. webSettings.setJavaScriptEnabled(true);  

WebSettings 還提供了很多其他有用的設置。比如,如果你在開發一個專用于Android應用中 WebView 的web app,那么你就可以通過 setUserAgentString()定義自定義用戶代理字符串(custom user agent string),然后通過在web頁面中查詢自定義用戶代理來確認正在請求你的web頁面的客戶端確實是Android應用。

將JavaScript 代碼綁定到Android 代碼

在開發專用于Android應用中 WebView 的web app時,你可以在你的Javascript代碼和客戶端的Android代碼間創建接口。例如,你的Javascript代碼可以調用Android代碼中的方法來展示一個Dialog,而不是使用Javascript中的alert()函數。

為了在你的Javascript和Android代碼間綁定一個新的接口,需要調用addJavascriptInterface(),傳給它一個類實例來綁定到Javascript,以及一個接口名讓Javascript可以調用以便來訪問類。

例如:你可以在你的Android應用中包括如下類:

  1. public class JavaScriptInterface { 
  2. Context mContext; 
  3. /** Instantiate the interface and set the context */ 
  4. JavaScriptInterface(Context c) { 
  5. mContext = c; 
  6. /** Show a toast from the web page */ 
  7. public void showToast(String toast) { 
  8. Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show(); 

在這個例子中,JavaScriptInterface讓web頁面可以使用showToast()方法來創建一個Toast 消息。

你可以通過 addJavascriptInterface()綁定這個類到在WebView 運行的Javascript,并將接口命名為Android。例如:

  1. WebView webView = (WebView) findViewById(R.id.webview); webView.addJavascriptInterface(new JavaScriptInterface(this), "Android"); 

這段代碼為在WebView 運行的Javascript創建了一個名為Android的接口。這時候,你的web app就能訪問JavaScriptInterface 類了。例如,下面是一些HTML以及Javascript,在用戶敲擊按鈕的時候,它們使用這個新接口創建一個toast消息:

  1. <input type="button" value="Say hello" onClick="showAndroidToast('Hello Android!')" /> 
  2.  
  3. <script type="text/javascript"> 
  4.     function showAndroidToast(toast) { 
  5.         Android.showToast(toast); 
  6.     } 
  7. </script> 

沒有必要從Javascript初始化Android接口, WebView會自動讓它可以為你的web頁面所用。所以,在按下按鈕的時候,showAndroidToast() 函數會用這個Android接口來調用 JavaScriptInterface.showToast() 方法。

注意:綁定到你的Javascript的對象在另一個線程中運行,而不是在創建它的線程中運行。

小心:使用 addJavascriptInterface()可以讓Javascript控制你的Android應用。這是一把雙刃劍,有用的同時也可能帶來安全威脅。當WebView 中的HTML不可信時(例如,HTML的部分或者全部都是由一個未知的人或者進程提供的),那么一個攻擊者就可能使用HTML來執行客戶端的任何他想要的代碼。因此,不應該使用addJavascriptInterface() ,除非WebView中的所有HTML以及Javascript都是你自己寫的。你同樣不應該讓用戶在你的WebView可以定向到另外一個不是你自己的web頁面上去(相反,讓用戶的默認瀏覽器應用打開外部鏈接——用戶瀏覽器默認打開所有URL鏈接,因此一定要小心處理頁面導航,像下面一節所描述的那樣。)

處理頁面導航

當用戶點擊一個WebView中的頁面的鏈接時,默認是讓Android啟動一個可以處理URL的應用。通常,是由默認的瀏覽器打開并加載目標URL的。然而,你可以在 WebView中覆蓋這一行為,那么鏈接就會在WebView中打開。這樣,你就可以讓用戶通過保存在WebView中的瀏覽記錄前進或者后退了。

要想讓用戶可以通過點擊打開鏈接,只需要使用 setWebViewClient()為WebView提供一個 WebViewClient即可。例如:

  1. WebView myWebView = (WebView) findViewById(R.id.webview); 
  2. myWebView.setWebViewClient(new WebViewClient()); 

這樣就可以了。現在所有用戶點擊的鏈接都會直接在WebView中加載了。

如果你想要對于加載的鏈接的位置有更多控制,你可以創建自己的WebViewClient,覆蓋 shouldOverrideUrlLoading()方法。例如:

  1. private class MyWebViewClient extends WebViewClient { 
  2. @Override 
  3. public boolean shouldOverrideUrlLoading(WebView view, String url) { 
  4. if (Uri.parse(url).getHost().equals("www.example.com")) { 
  5. // This is my web site, so do not override; let my WebView load the page 
  6. return false
  7. // Otherwise, the link is not for a page on my site, so launch another Activity that handles URLs 
  8. Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); 
  9. startActivity(intent); 
  10. return true

然后為 WebView創建一個新的 WebViewClient的實例。

  1. WebView myWebView = (WebView) findViewById(R.id.webview); 
  2. myWebView.setWebViewClient(new MyWebViewClient()); 

現在當用戶點擊鏈接的時候,系統會調用shouldOverrideUrlLoading(),來檢查URL host是否和某個特定的域匹配(如上面的定義)。如果匹配,那么該方法就返回false,不去覆蓋URL加載(它仍然讓WebView 像往常一樣加載URL)。如果不匹配,那么就會創建一個Intent來加載默認活動(default Activity)來處理URLs(通過用戶默認的web瀏覽器解析)。

歷史記錄導航

當你的 WebView覆蓋了URL加載,它會自動生成歷史訪問記錄。你可以通過 goBack() 或 goForward()向前或向后訪問已訪問過的站點。

例如,下面的代碼實現了通過 Activity來利用設備的后退按鈕來向后導航:

  1. @Override 
  2. public boolean onKeyDown(int keyCode, KeyEvent event) { 
  3. // Check if the key event was the BACK key and if there's history 
  4. if ((keyCode == KeyEvent.KEYCODE_BACK) && myWebView.canGoBack() { 
  5. myWebView.goBack(); 
  6. return true
  7. // If it wasn't the BACK key or there's no web page history, bubble up to the default 
  8. // system behavior (probably exit the activity) 
  9. return super.onKeyDown(keyCode, event); 

如果有歷史訪問記錄可供訪問,canGoBack() 方法會返回true。類似地,你可以使用canGoForward()來檢查是否有向前訪問歷史。如果你不做這個檢查,那么一旦用戶訪問到歷史記錄最后一項,goBack() 或 goForward()什么都不會做。

責任編輯:佚名 來源: Web App Trend
相關推薦

2012-02-09 10:39:37

AndroidWeb App官方文檔

2012-02-16 10:18:48

AndroidWeb App官方文檔

2012-02-16 10:31:02

AndroidWeb App官方文檔

2012-02-13 16:39:03

AndroidWeb App官方文檔

2014-01-16 14:30:43

storm安裝部署

2020-12-04 12:22:03

鴻蒙UI組件

2011-07-20 11:29:48

jQuery Mobi手機新聞瀏覽器

2020-12-01 15:54:08

鴻蒙構建系統

2010-12-08 10:36:34

系統架構設計師

2023-03-02 20:59:41

特斯拉機器人

2009-07-09 00:25:00

Scala參數化

2009-07-09 00:25:00

ScalaListTuple

2015-07-02 16:10:11

UIStackViewiOS 9

2018-10-15 10:22:51

2017-12-06 14:46:41

計算機技術等級考試

2011-04-11 14:45:41

性能設計官方文檔Android

2017-05-25 12:30:44

AndroidApp開發架構

2011-10-18 08:59:46

Sencha ToucHTML5

2010-08-31 17:12:13

2014-04-16 00:21:48

Office 365微軟公有云
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品99久久久久久久久久久久 | 亚洲一区二区在线 | 精品国产免费一区二区三区演员表 | 中文字幕 欧美 日韩 | 天天狠狠 | 日韩成人免费av | 成人区精品一区二区婷婷 | 国产精品永久久久久久久www | 伊人最新网址 | 国产日韩欧美精品一区二区 | 欧美一级片在线看 | 一区二区三区四区日韩 | 成人3d动漫一区二区三区91 | 国产精品国产三级国产aⅴ中文 | 精品入口麻豆88视频 | 国产91丝袜在线播放 | 成人av网站在线观看 | 国产91av视频| 久久精品亚洲欧美日韩精品中文字幕 | 国产中文字幕在线观看 | 日韩一区中文字幕 | 国产在线一区二 | 亚洲综合国产 | 天天操天天玩 | 色婷婷国产精品 | 免费观看一区二区三区毛片 | 久久久久国产精品午夜一区 | 日韩欧美中文字幕在线观看 | 在线成人av | 国产大学生情侣呻吟视频 | 一区二区三区四区在线视频 | 正在播放一区二区 | 福利视频一二区 | 人人澡人人射 | 国产ts人妖系列高潮 | 日韩一区二区在线视频 | 天久久 | 午夜影院在线观看免费 | 欧美一级小视频 | 国产美女h视频 | 国产精品久久国产精品久久 |