Webview 与JS 交互
2015-05-30 20:33
435 查看
现在的Android 项目 中经常使用Html5 与Webview 来显示数据 ,其中会涉及到Webview与js交互.
1.启用javascript:
mWebView.getSettings().setJavaScriptEnabled(true);
2. 添加接口,实现JS调用java方法:
public void addJavascriptInterface (Object object, String name)
Object是JS调用本地的类的对象,name是对象的别名,在JS可以用这个别名+点语法+方法名就可以调用本地的方法。例如 :
mWebView.addJavascriptInterface(this, "jsDemo");
//在activity中添加一个方法供js调用
public void clickOnAndroid() {
Toast.makeText(getApplicationContext(),"js调用android的方法clickOnAndroid",0).show();
}
js代码:
<a onClick="window.jsDemo.clickOnAndroid()">
3.java 调用js, 实现更新img图片
注册点击事件:
public void callJS(View v){
mHandler.post(new Runnable() {
public void run() {
Toast.makeText(getApplicationContext(),"callJS",0).show();
mWebView.loadUrl("javascript:callJSFromAndroid()");
}
});
}
js代码:
<script language="javascript" charset="utf-8">
function callJSFromAndroid() {
document.getElementById("droid").src="app_small_icon.png";//更换图片
}
</script>
4. 捕获JS的alert:
mWebView.setWebChromeClient(new MyWebChromeClient());
5.获取js的返回值
仔细观察会发现WebView的loadUrl方法是没有返回值的,那要是想要获取JS方法的返回值就该怎么做呢?
在loadUrl调用JS的一个方法,然后JS执行方法的时候,再调用Android本地的一个方法,并把返回值作为参数传递下来
6.html页面跳转的处理
WebView默认用系统自带浏览器处理页面跳转。 为了让页面跳转在当前WebView中进行,重写WebViewClient。
但是按BACK键时,不会返回跳转前的页面,而是退出本Activity。重写onKeyDown()方法来解决此问题。
1.启用javascript:
mWebView.getSettings().setJavaScriptEnabled(true);
2. 添加接口,实现JS调用java方法:
public void addJavascriptInterface (Object object, String name)
Object是JS调用本地的类的对象,name是对象的别名,在JS可以用这个别名+点语法+方法名就可以调用本地的方法。例如 :
mWebView.addJavascriptInterface(this, "jsDemo");
//在activity中添加一个方法供js调用
public void clickOnAndroid() {
Toast.makeText(getApplicationContext(),"js调用android的方法clickOnAndroid",0).show();
}
js代码:
<a onClick="window.jsDemo.clickOnAndroid()">
3.java 调用js, 实现更新img图片
注册点击事件:
public void callJS(View v){
mHandler.post(new Runnable() {
public void run() {
Toast.makeText(getApplicationContext(),"callJS",0).show();
mWebView.loadUrl("javascript:callJSFromAndroid()");
}
});
}
js代码:
<script language="javascript" charset="utf-8">
function callJSFromAndroid() {
document.getElementById("droid").src="app_small_icon.png";//更换图片
}
</script>
4. 捕获JS的alert:
mWebView.setWebChromeClient(new MyWebChromeClient());
final class MyWebChromeClient extends WebChromeClient { @Override public boolean onJsAlert(WebView view, String url, String message, JsResult result) { Log.d(LOG_TAG, message); result.confirm(); builder.setTitle("onJsAlert").setMessage(message) .setPositiveButton("OK", null).show(); return true; } }
5.获取js的返回值
仔细观察会发现WebView的loadUrl方法是没有返回值的,那要是想要获取JS方法的返回值就该怎么做呢?
在loadUrl调用JS的一个方法,然后JS执行方法的时候,再调用Android本地的一个方法,并把返回值作为参数传递下来
6.html页面跳转的处理
WebView默认用系统自带浏览器处理页面跳转。 为了让页面跳转在当前WebView中进行,重写WebViewClient。
但是按BACK键时,不会返回跳转前的页面,而是退出本Activity。重写onKeyDown()方法来解决此问题。
mWebView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url);//使用当前WebView处理跳转 return true;//true表示此事件在此处被处理,不需要再广播 } @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { //有页面跳转时被回调 } @Override public void onPageFinished(WebView view, String url) { //页面跳转结束后被回调 } @Override public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { Toast.makeText(WebViewDemo.this, "Oh no! " + description, Toast.LENGTH_SHORT).show(); } });
相关文章推荐
- python遇到AttributeError: 'str' object has no attribute '_getAssertEqualityFunc'问题解决过程
- Android系统中标准Intent的使用
- Android之Activity LaunchMode
- Intent详解
- android编译错误--/usr/bin/ld: cannot find -lz
- Android SlidingMenu 使用详解
- OC视频笔记3.1(Foundation框架,NSObject里面的方法)3.2(isKindOfClass和isMemberOfClass)
- android ScrollView滚动距离和判断滚动停止状态
- Android 开发工具类 31_WebService 获取手机号码归属地
- Android 监听ScrollView的滑动
- 菜鸟学Android笔记(九):Schema之名称空间
- iOS中使用RNCryptor对资源文件加密
- iOS 错误集锦与断点调试
- 获取标题栏(actionbar)、状态栏高度的办法 onCreate()有效
- Android 开发工具类 30_sendXML
- appium初学环境搭建
- 我的Android进阶之旅------>Android使用9Patch图片作为不失真背景
- 解决Genymotion运行Android 5.0一直卡在开机界面
- 层次聚类法 hierarchical clustering approach
- Swift面向对象-枚举