使用webView中的javaScript調(diào)用Android方法

之前接觸過的webView只是了解,知道Android提供了webView組件,它本身就是瀏覽器的實現(xiàn),內(nèi)核基于開源的WebKit引擎。webView和普通的ImageView組件的用法基本類似,有大量的方法來執(zhí)行瀏覽器操作,

成都創(chuàng)新互聯(lián)是專業(yè)的黎城網(wǎng)站建設(shè)公司,黎城接單;提供成都網(wǎng)站設(shè)計、成都做網(wǎng)站,網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行黎城網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

  比如 void goBack()后退  

            void goForward()  前進(jìn) 

            void loadUrl(String url) 加載指定的Url對應(yīng)的網(wǎng)頁

             boolean zoomln()放大網(wǎng)頁

等等。

另外,webView也提供了架子html代碼的方法loadData(String baseUrl,String mimeType ,String encoding。。。。).

  現(xiàn)在因為接觸到要加載html網(wǎng)頁并且有交互,所以看了一下Android這塊支持調(diào)用Android方法的webview。

   使用webView中的javaScript調(diào)用Android

   很多時候,webView加載頁面是帶的javaScript腳本,比如網(wǎng)頁上有個按鈕,用戶點擊按鈕之后將會有相應(yīng),因為按鈕是html頁面上的,所以按鈕只能激發(fā)一段javaScript腳本,這就需要javaScript腳本調(diào)用Android方法來實現(xiàn)響應(yīng)。

  為了讓webView飛javaScript調(diào)用Android方法,webView提供了一個配套的webSettings工具類,該類提供了大量的方法來管理webView的選項設(shè)置。

   WebView的javaScript中調(diào)用Android方法的步驟有三個:

   1、調(diào)用webView關(guān)聯(lián)的webSettings的setJavaScriptEnabled(true),啟用javaScript調(diào)用功能

    2、調(diào)用webView的addjavasriptInterface(Object object,String name)方法將object暴露給javaScript

    3、在javaScript腳本中通過剛才暴露的name對象調(diào)用Android方法。

 

大概代碼如下,不過完整代碼在附件中可以下載。

 

activity

 

public class MainActivity extends Activity {

 private WebView webView;
 
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  webView = (WebView)findViewById(R.id.webview_s);
 //加載本地的assets下 的testhtml文件,也可以加載網(wǎng)頁或者服務(wù)器上的 網(wǎng)頁

 webView.loadUrl("file:///android_asset/test.html");
  //獲取websettings對象

WebSettings webSetting = webView.getSettings();
  //啟用javaScript功能

webSetting.setJavaScriptEnabled(true);
 //將MyObject對象暴露給javaScript腳本,這樣test.html網(wǎng)頁 的javaScript就可以通過myObj來調(diào)用      //  MyObject的方法;

 webView.addJavascriptInterface(new MyObject(this), "myObj");
  
 }

}

 

 //這個類就是自定義的,

public class MyObject {
 Context mContext;
 public  MyObject (Context c){
  mContext = c;
 }
public void showToast(String name){
 Toast.makeText(mContext, name, Toast.LENGTH_SHORT).show();
}
}

 

 

test.html

  按鈕的   javaScript通過muObj來調(diào)用方法

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標(biāo)題文檔</title>

<style type="text/css">
.highlight{ background:#FF3300;
}
</style>
</head>

<body>
<div id="panel">
 <h6 class="head">什么是jquery?</h6>
    <div class="content">
    JavaScript作為Web開發(fā)的客戶端標(biāo)準(zhǔn)語言,逐漸被人們重視。由于JavaScript僅定義了
本的語法規(guī)范和邏輯結(jié)構(gòu),
    </div>
</div>
<input type ="button" value = "打招呼" onclick ="myObj.showToast('eeee');"/>

</body>
</html>

 

網(wǎng)頁題目:使用webView中的javaScript調(diào)用Android方法
文章路徑:http://muchs.cn/article10/picigo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站內(nèi)鏈、移動網(wǎng)站建設(shè)、網(wǎng)站營銷App設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)