• Android与html5交互 -- WebView使用(一)


    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对象方法调用的权

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

    转载:http://blog.csdn.net/dongyaqin/article/details/50925388  不吃腥的猫博客

    只做学习交流用,给自己留个备份 ,只使用到了  加上注解@JavascriptInterface这个方法 弹出窗口

  • 相关阅读:
    第七课——iOS数据持久化
    第三章-动态规划
    IOS第五课——Gesture and TableView
    第六课——UIDynamicAnimator
    文本居中换行、边框设置
    属性优先级、图片属性设置、内联标签设置大小
    打开、悬浮、访问、点击、状态用:
    属性选择器用【】
    组合使用用逗号,
    3种选择器的使用方式
  • 原文地址:https://www.cnblogs.com/bruceli-net/p/5729205.html
Copyright © 2020-2023  润新知