您好,登錄后才能下訂單哦!
之前接觸過的webView只是了解,知道Android提供了webView組件,它本身就是瀏覽器的實現(xiàn),內(nèi)核基于開源的WebKit引擎。webView和普通的ImageView組件的用法基本類似,有大量的方法來執(zhí)行瀏覽器操作,
比如 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>
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。