Android WebView的使用方法及与JS 相互调用
1、添加网络权限
<uses-permission android:name="android.permission.INTERNET" />
2、WebSettings 对访问页面进行设置。
WebView mWebView = new WebView(this); WebSettings webSettings = mWebView .getSettings();//支持获取手势焦点,输入用户名、密码或其他 mWebView.requestFocusFromTouch(); webSettings.setJavaScriptEnabled(true); //支持js webSettings.setUseWideViewPort(true); //将图片调整到适合webview的大小 webSettings.setLoadWithOverviewMode(true); // 缩放至屏幕的大小 webSettings.setSupportZoom(true); //支持缩放,默认为true。是下面那个的前提。 webSettings.setBuiltInZoomControls(true); //设置内置的缩放控件。 webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件 webSettings.setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持内容重新布局 webSettings.supportMultipleWindows(); //多窗口 webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); //关闭webview中缓存 webSettings.setAllowFileAccess(true); //设置可以访问文件 webSettings.setNeedInitialFocus(true); //当webview调用requestFocus时为webview设置节点 webSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口 webSettings.setLoadsImagesAutomatically(true); //支持自动加载图片 webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式
3、页面加载方式
//加载一个网页: mWebView.loadUrl(); //加载apk包中的一个html页面 mWebView.loadUrl(); //加载手机本地的一个html页面的方法: mWebView.loadUrl("content://com.android.htmlfileprovider/sdcard/test.html");
4、WebView 的两个重要方法 WebViewClient 和 WebChromeClient
WebViewClient就是帮助WebView处理各种通知、请求事件的。
//打开网页时不调用系统浏览器, 而是在本WebView中显示: mWebView.setWebViewClient(new WebViewClient(){ @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } }); //将上面定义的webviewclinet设置给webview mWebView.setWebViewClient(webViewClient);
下面介绍 WebView 的一些事件:
WebViewClient mWebViewClient = new WebViewClient() { shouldOverrideUrlLoading(WebView view, String url); //在网页上的所有加载都经过这个方法,这个函数我们可以做很多操作。 //比如获取url,查看url.contains(“add”),进行添加操作 shouldOverrideKeyEvent(WebView view, KeyEvent event); //重写此方法才能够处理在浏览器中的按键事件。 onPageStarted(WebView view, String url, Bitmap favicon) ; //这个事件就是开始载入页面调用的,我们可以设定一个loading的页面,告诉用户程序在等待网络响应。 onPageFinished(WebView view, String url); //在页面加载结束时调用。同样道理,我们可以关闭loading 条,切换程序动作。 onLoadResource(WebView view, String url) ; // 在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。 onReceivedError(WebView view, int errorCode, String description, String failingUrl); // (报告错误信息) doUpdateVisitedHistory(WebView view, String url, boolean isReload); //(更新历史记录) onFormResubmission(WebView view, Message dontResend, Message resend); //(应用程序重新请求网页数据) onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host,String realm); //(获取返回信息授权请求) onReceivedSslError(WebView view, SslErrorHandler handler, SslError error); //重写此方法可以让webview处理https请求。 onScaleChanged(WebView view, float oldScale, float newScale); // (WebView发生改变时调用) onUnhandledKeyEvent(WebView view, KeyEvent event); //(Key事件未被加载时调用) }
WebChromeClient是辅助WebView处理Javascript的对话框,网站图标,网站title,加载进度等。
WebChromeClient mWebChromeClient = new WebChromeClient() { //获得网页的加载进度,显示在右上角的TextView控件中 @Override public void onProgressChanged(WebView view, int newProgress) { if (newProgress < 100) { String progress = newProgress + "%"; } else { } } //获取Web页中的title用来设置自己界面中的title //当加载出错的时候,比如无网络,这时onReceiveTitle中获取的标题为 找不到该网页, //因此建议当触发onReceiveError时,不要使用获取到的title @Override public void onReceivedTitle(WebView view, String title) { MainActivity.this.setTitle(title); } @Override public void onReceivedIcon(WebView view, Bitmap icon) { // } @Override public boolean onCreateWindow(WebView view, boolean isDialog, boolean isUserGesture, Message resultMsg) { // return true; } @Override public void onCloseWindow(WebView window) { } //处理alert弹出框,html 弹框的一种方式 @Override public boolean onJsAlert(WebView view, String url, String message, JsResult result) { // return true; } //处理confirm弹出框 @Override public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, JsPromptResult result) { // return true; } //处理prompt弹出框 @Override public boolean onJsConfirm(WebView view, String url, String message, JsResult result) { // return true; } }; //同样,将上面定义的WebChromeClient设置给WebView: webView.setWebChromeClient(mWebChromeClient);
5、调用 JS 代码
WebSettings webSettings = mWebView .getSettings(); webSettings.setJavaScriptEnabled(true);//这里必须设置 mWebView.addJavascriptInterface(new InsertObj(), "jsObj");
以下方法是 Android 和 JS 的交互
public class InsertObj extends Object { private static Activity mActivity; private static WebView mWebView; public InsertObj(Activity activity, WebView webView) { mActivity = activity; mWebView = webView; } //给html提供的方法,js中可以通过:var str = window.jsObj.HtmlcallJava(); 获取到 @JavascriptInterface public String HtmlcallJava() { return "Html call Java"; } //给html提供的有参函数 : window.jsObj.HtmlcallJava2("IT-homer blog"); @JavascriptInterface public String HtmlcallJava2(final String result) { return "Html call Java : " + result; } //Html给我们提供的函数 @JavascriptInterface public static void JavacallHtml() { mActivity.runOnUiThread(new Runnable() { @Override public void run() { //这里是调用方法 mWebView.loadUrl("javascript: showFromHtml()"); Toast.makeText(mActivity, "clickBtn", Toast.LENGTH_SHORT).show(); } }); } //Html给我们提供的有参函数 @JavascriptInterface public static void JavacallHtml2(final String param) { mActivity.runOnUiThread(new Runnable() { @Override public void run() { mWebView.loadUrl("javascript: showFromHtml2('"+param+"')"); Toast.makeText(mActivity, "clickBtn2", Toast.LENGTH_SHORT).show(); } }); } }
<!DOCTYPE html> <html> <head> <meta content="text/html; charset=utf-8" http-equiv="Content-Type"> <title>无标题 1</title> <script type="text/javascript"> function HtmlcallJava(){ var str = window.jsObj.HtmlcallJava(); alert(str); } function HtmlcallJava2(){ var str = window.jsObj.HtmlcallJava2("HTML"); alert(str); } function showFromHtml() { alert("我是js方法,我被Android后台调用"); } function showFromHtml2(result) { alert("我是js方法,我被Android后台调用 "+result); } </script> </head> <body> <button onclick="HtmlcallJava()">HtmlcallJava</button> <button onclick="HtmlcallJava2()">HtmlcallJava2</button> </body> </html>
6、WebView 返回键
public boolean onKeyDown(int keyCode, KeyEvent event) { if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) { mWebView.goBack(); return true; } return super.onKeyDown(keyCode, event); }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持,如有疑问请留言或者到本站社区交流讨论,大家共同进步!
本文向大家介绍Android和JavaScript相互调用的方法,包括了Android和JavaScript相互调用的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android和JavaScript相互调用的方法。分享给大家供大家参考,具体如下: Html页面和Java代码结合的方式一般用在界面经常被更改 的情况下,可以讲html放在网络中,软件一打开就会访问网络获取到最新的界面。
本文向大家介绍详解Android JS相互调用,包括了详解Android JS相互调用的使用技巧和注意事项,需要的朋友参考一下 最近在研究Android、JS相互调用,之前没怎么接触过,只知道loadUrl()就可以加载一个网页了,研究过之后发现Android可以调JS,JS也可以调Android原生控件,很开心啊。下面小编就开始喽: 原理就是Java和JS调用,在Android中是通过WebVi
本文向大家介绍Js调用Java方法并互相传参的简单实例,包括了Js调用Java方法并互相传参的简单实例的使用技巧和注意事项,需要的朋友参考一下 Js通过PhoneGap调用Java方法并互相传参的。 一、JAVA代码 写一个类,该类继承自Plugin并重写execute方法。 三、Javascript文件中注册插件 新建一个.js文件,并把该文件和phonegap文件放在同一目录。(新建一个sim
本文向大家介绍总结VC与易语言DLL互相调用的方法,包括了总结VC与易语言DLL互相调用的方法的使用技巧和注意事项,需要的朋友参考一下 在编写程序的时候往往需要调用到别的语言编写的DLL文件,下面先来看一下在易语言中如何调用VC编写的DLL呢,首先用VC编写一个简单的DLL文件,代码如下: 这是一个简单的两个数加法操作,返回两个数相加的结果,这里我生成的是MFC DLL,并且需要在def中导出ad
本文向大家介绍js数组与字符串的相互转换方法,包括了js数组与字符串的相互转换方法的使用技巧和注意事项,需要的朋友参考一下 熟悉js的朋友很多都遇到过js的数组与字符串相互转换的情况,本文就此作一简单介绍,示例如下: 一、数组转字符串 需要将数组元素用某个字符连接成字符串,示例代码如下: 二、字符串转数组 实现方法为将字符串按某个字符切割成若干个字符串,并以数组形式返回,示例代码如下:
本文向大家介绍对vue中methods互相调用的方法详解,包括了对vue中methods互相调用的方法详解的使用技巧和注意事项,需要的朋友参考一下 如下所示: 最近在学习vue,并用vue+vue-router+axios+elementUI做了一个pos收银系统的前端页面,但是中间遇到methods里的方法调用问题。本身源码是没有调用的,但是我想直接调用多方便,结果出错了……然后百度了一波,终于