Android与html5交互 -- JavascriptInterface

Android中使用WebView可加载html5,具体步骤如下:

(前提:本地Html5存放到assets文件夹下)

一:使用WebView加载Html5,简单显示

1:清单文件中添加访问权限:android.permission.INTERNET

2:Activity中生成WebView组件,布局文件中添加<WebView>控件,或者动态添加

3:本地文件html5中有js的话,webview必须设置支持js的属性:webview.getSettings().setJavaScriptEnabled(true);  这里可以设置其它属性,随后附上

4:使用WebView加载html5文件 :webView.loadUrl("file:///android_asset/XX.html");

二:WebView与html5之间的交互

<1>js调用Android中的函数

1:webView.addJavascriptInterface(obj,str);

参数一:android中的实例对象

参数二:js中别名

注:如果js中调用此对象的某方法,须在此公有方法前加上注解@JavascriptInterface,否则访问不了,目前只知道这种写法只能调用对象的方法。

如果不加webView.setWebChromeClient()这个方法,js中的alert对话框将不会提示。

2:js中使用str.xx()/window.str.xx()调用android中的方法

(Android中的list须转换成json的字符串形式传入到js中,用eval(json)进行获取)

<2>anroid中调用js的方法

1:js中编写带参或不带参的方法 如function init(){alert("js中方法显示");}

2:用webView.loadUrl("javascript:init()");进行调用显示即可

三:webView加载html5全屏显示解决办法

1:<meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,initial-scale=1.0" user-scalable=no />

四:webView的属性(必要的)

myWebView.getSettings().setJavaScriptEnabled(true);//可以使用js

myWebView.getSettings().setDefaultTextEncodingName("GBK");//设置编码格式

myWebView.setWebViewClient(newWebViewClient());//限制在webview中打开网页,不用默认浏览器

myWebView.getSettings().setBuiltInZoomControls();//设置是否支持缩放

myWebView.addJavascriptInterface(obj,str);//向html页面注入java对象,在Android4.2之

前并未限制此方法,根据java反射机制造成攻击,所以在此版本之后则限制了js对java对象方法调用的权

限(必须声明注解公共的方法才能被页面调用)





 
 
 
											在这里声明,如有不明确的地方请各位留言指教。
 
 

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值