iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >如何在Android中使用WebView方法
  • 683
分享到

如何在Android中使用WebView方法

androidwebview 2023-05-30 23:05:10 683人浏览 独家记忆
摘要

如何在Android中使用WEBView方法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Android WebView的使用方法及与JS 相互调用1、添加网络权限<us

如何在Android中使用WEBView方法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

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中使用WebView方法的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: 如何在Android中使用WebView方法

本文链接: https://www.lsjlt.com/news/221926.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何在Android中使用WebView方法
    如何在Android中使用WebView方法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Android WebView的使用方法及与JS 相互调用1、添加网络权限<us...
    99+
    2023-05-30
    android webview
  • webview如何在Android中使用
    这篇文章给大家介绍webview如何在Android中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Androi1. 打开网页时不调用系统浏览器, 而是在本WebView中显示:mWebView.setWebVie...
    99+
    2023-05-30
    android webview
  • WebView如何在Android应用中使用
    这期内容当中小编将会给大家带来有关WebView如何在Android应用中使用 ,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。WebView基本使用 WebView是View的一个子类,可以让你在acti...
    99+
    2023-05-31
    android webview roi
  • Android中ViewPager如何使用WebView
    小编给大家分享一下Android中ViewPager如何使用WebView,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Android 中ViewPager中使用...
    99+
    2023-05-30
    android viewpager webview
  • Android WebView的使用方法总结
     Android WebView的使用方法  Android app打开H5页一般要实现如下需求:打开指定url网页;2、点击链接可以跳转到下一页,并更新标题;3、按back键或左箭头可以返回上一页;4、当webview...
    99+
    2023-05-30
    android webview roi
  • android webview使用的方法是什么
    Android中使用WebView控件展示网页内容的方法如下: 在布局文件中添加WebView控件: <WebView ...
    99+
    2024-04-02
  • setContentView()方法如何在Android 中使用
    这篇文章给大家介绍setContentView()方法如何在Android 中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。概述Dialog在Android中是一个很优秀的工具。在使用Dialog时,我们一般都会自...
    99+
    2023-05-31
    setcontentview android roi
  • View.onMeasure方法如何在Android中使用
    本篇文章为大家展示了View.onMeasure方法如何在Android中使用 ,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Android View.onMeasure方法详解及实例View在屏幕...
    99+
    2023-05-31
    android view.onmeasure sur
  • 如何在Android中利用studio点击跳转WebView
    这篇文章主要介绍了如何在Android中利用studio点击跳转WebView,此处通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考价值,需要的朋友可以参考下:Android是什么Android是一种基于Linux内核的自...
    99+
    2023-05-30
    android studio webview
  • getevent方法如何在Android应用中使用
    本篇文章给大家分享的是有关 getevent方法如何在Android应用中使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。首先看-p 选项, -p选项用于输出input设备相...
    99+
    2023-05-31
    android getevent roi
  • imageview.ScaleType方法如何在Android应用中使用
    今天就跟大家聊聊有关imageview.ScaleType方法如何在Android应用中使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Android中imageview.Scal...
    99+
    2023-05-31
    android imageview.scaletype age
  • 如何在Android中利用WebView打开TextView超链接
    今天就跟大家聊聊有关如何在Android中利用WebView打开TextView超链接,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。使用Html常规方法,给定一段标准html文档,使...
    99+
    2023-05-31
    android webview textview
  • html.fromhtml方法如何在Android项目中使用
    这篇文章给大家介绍html.fromhtml方法如何在Android项目中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Android中html.fromhtml  在android中,有一个容易遗忘的H...
    99+
    2023-05-31
    android html.fromhtml roi
  • Android应用中WebView无法使用 H5 input type="file" 如何解决
    Android应用中WebView无法使用 H5 input type="file" 如何解决?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。解决方法如下...
    99+
    2023-05-31
    android webview npu
  • WebView如何使用
    这篇文章主要介绍“WebView如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“WebView如何使用”文章能帮助大家解决问题。   WebView是and...
    99+
    2024-04-02
  • Android中如何使用onSaveInstanceState()方法
    Android中如何使用onSaveInstanceState()方法,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Android 中 onSaveInstanceStat...
    99+
    2023-05-30
    android onsaveinstancestate()
  • Android开发如何使用WebView打造web app
    这篇文章主要为大家展示了“Android开发如何使用WebView打造web app”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android开发如何使用WebView打造web&n...
    99+
    2023-06-29
  • Android项目中如何在webview页面中上传文件
    本篇文章为大家展示了Android项目中如何在webview页面中上传文件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Android webview在默认情况下是不支持网页中的文件上传功能的;如果...
    99+
    2023-05-31
    webview android roi
  • Android开发中使用WebView控件浏览网页的方法详解
    本文实例讲述了Android开发中使用WebView控件浏览网页的方法。分享给大家供大家参考,具体如下:项目中遇到数学展示问题,常规的Textview显示处理不了数学公式,利用图片生成对服务器又产生较大压力,经过查询,可以通过webview...
    99+
    2023-05-30
    android webview roi
  • Android中使用webview时出现内存泄露如何解决
    Android中使用webview时出现内存泄露如何解决,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1.避免在xml直接写webview控件,这样会引用activity,...
    99+
    2023-05-31
    android webview
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作