新聞中心
Js調(diào)用Android的方法
1、初始化WebView
創(chuàng)新互聯(lián)是一家專注于網(wǎng)站制作、做網(wǎng)站與策劃設(shè)計(jì),綏化網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:綏化等地區(qū)。綏化做網(wǎng)站價(jià)格咨詢:18980820575
X5WebView? webView =new X5WebView(this,null);我這里用的是騰訊的TBS瀏覽服務(wù).詳情參考上一篇文章:
2、設(shè)置初始化WebSetting
3、給WebView添加addJavascriptInterface()
例如:
JS怎樣調(diào)用Android本地原生方法
在android中調(diào)用本地js文件里的方法并得到返回值其方法如下:
Android中內(nèi)置了WebKit模塊,而該模塊的Java層視圖類就是WebView,所有需要使用Web瀏覽器功能的Android都需要?jiǎng)?chuàng)建該視圖類對(duì)象顯示和處理請(qǐng)求的網(wǎng)絡(luò)資源。目前WebKit支持Http、Https、Ftp和JavaScript請(qǐng)求。下面是在Android中調(diào)用JavaScript方法以及如何在js中調(diào)用本地方法。
1、在Assets下放一個(gè)簡(jiǎn)單的html文件jstest.html
!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" ""
HTML
HEAD
meta name="viewport" content="width=device-width, target-densitydpi=device-dpi" /
META http-equiv="Content-Type" content="text/html; charset=UTF-8"
script
function showMsg(){
alert("hello world!");
}
function showMsgInAndroid(){
myjs.showMsg('hello in android!');
}
/script
/HEAD
BODY
span測(cè)試js使用/span
button id='btntest' onclick='showMsgInAndroid()'調(diào)用android方法/button
/BODY
/HTML
2、布局文件main.xml
?xml version="1.0" encoding="utf-8"?
RelativeLayout
android:id="@+id/rl_main"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
xmlns:android=""
WebView
android:id="@+id/wv_test"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_above="@+id/btn_showmsg"/
Button
android:id="@+id/btn_showmsg"
android:layout_width="200dip"
android:layout_height="40dip"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:text="調(diào)用html中js方法"/
/RelativeLayout
3、然后是Activity,MainActivity.java
package com.harold.jstest;
import com.harold.base.JSKit;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.view.View;
import android.view.View.OnClickListener;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.widget.Button;
public class MainActivity extends Activity {
private WebView mWebView;
private Button btnShowInfo;
private JSKit js;
private Handler mHandler = new Handler();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
//初始化控件
mWebView = (WebView) findViewById(R.id.wv_test);
btnShowInfo = (Button) findViewById(R.id.btn_showmsg);
//實(shí)例化js對(duì)象
js = new JSKit(this);
//設(shè)置參數(shù)
mWebView.getSettings().setBuiltInZoomControls(true);
//內(nèi)容的渲染需要webviewChromClient去實(shí)現(xiàn),設(shè)置webviewChromClient基類,解決js中alert不彈出的問(wèn)題和其他內(nèi)容渲染問(wèn)題
mWebView.setWebChromeClient(new WebChromeClient());
mWebView.getSettings().setJavaScriptEnabled(true);
//把js綁定到全局的myjs上,myjs的作用域是全局的,初始化后可隨處使用
mWebView.addJavascriptInterface(js, "myjs");
mWebView.loadUrl("");
btnShowInfo.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
mHandler.post(new Runnable() {
@Override
public void run() {
//調(diào)用 HTML 中的javaScript 函數(shù)
mWebView.loadUrl("javascript:showMsg()");
}
});
}
});
}
}
4、最后是綁定全局js的類JSKit.java
package com.harold.base;
import android.widget.Toast;
import com.harold.jstest.MainActivity;
public class JSKit {
private MainActivity ma;
public JSKit(MainActivity context) {
this.ma = context;
}
public void showMsg(String msg) {
Toast.makeText(ma, msg, Toast.LENGTH_SHORT).show();
}
}
例子比較簡(jiǎn)單,代碼里都加了注釋,這里就不多說(shuō)了,本示例用的本地的html,如果訪問(wèn)網(wǎng)絡(luò)中的網(wǎng)頁(yè),別忘記在AndroidManifest.xml中加權(quán)限
uses-permission android:name="android.permission.INTERNET"/
JS 調(diào)用android的方法該怎么調(diào)
? ? ? body
? ? ? ? ? !-- Calls into the javascript interface for the activity --
? ? ? ? ? !-- 從HTML文件中調(diào)用activity中的函數(shù) --
? ? ? ? ? !-- 也就是從HTML到android程序 留意window.demo.clickOnAndroid()這句話 --
? ? ? ? ? a onClick="window.demo.clickOnAndroid()"Click/a
? ? ? /body
mWebView.addJavascriptInterface(new?DemoJavaScriptInterface(),?"demo");
final?class?DemoJavaScriptInterface?{??
DemoJavaScriptInterface()?{??
}??
/**?
*?This?is?not?called?on?the?UI?thread.?Post?a?runnable?to?invoke?
*?
*?loadUrl?on?the?UI?thread.?
*?
*/??
public?void?clickOnAndroid()?{????????//?注意這里的名稱。它為clickOnAndroid(),注意,注意,嚴(yán)重注意??
mHandler.post(new?Runnable()?{??
public?void?run()?{??
Toast.makeText....??
}??
});??
}??
}
文章標(biāo)題:js調(diào)用android的方法,js調(diào)用android的方法返回值
標(biāo)題來(lái)源:http://fisionsoft.com.cn/article/dsihidc.html