当前位置:首页 > 芯闻号 > 充电吧
[导读]有时候我们可能会碰到一些比较特殊的需求,比如说要求在应用程序里展示一些网页。相信每个人都知道,加载和显示网页通常都是浏览器的任务,但是需求里又明确指出,不允许打开系统浏览器,而我们当然也不可能自己去编

有时候我们可能会碰到一些比较特殊的需求,比如说要求在应用程序里展示一些网页。相信每个人都知道,加载和显示网页通常都是浏览器的任务,但是需求里又明确指出,不允许打开系统浏览器,而我们当然也不可能自己去编写一个浏览器出来,这时应该怎么办呢?

不用担心,Android 早就已经考虑到了这种需求,并提供了一个 WebView控件,借助它我们就可以在自己的应用程序里嵌入一个浏览器,从而非常轻松地展示各种各样的网页。

一、WebView通过Url加载网页

WebView是View的子类,能够让一个网页内容看起来像是你应用程序的一部分一样。它只提供页面显示的功能,默认情况下不提供浏览器应具备的导航等功能。

首先我们来看一下WebView的简单使用:

1、获得WebView的实例;

2、调用WebView类中的loadUrl(String url)方法,加载指定的网址;

3、在工程的清单文件中添加上网权限

清单文件中的上网权限:

Java代码:

public class MainActivity extends Activity {

WebView vb;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

vb = (WebView) findViewById(R.id.webView1);

vb.loadUrl("http://www.baidu.com");

}

}

当运行上面的代码后你会发现,程序会启动默认的浏览器来打开我们指定的网址,但是我们所希望的是在当前的应用中显示网页,那下面给大家介绍WebViewClient这个类以及其中的一些常用方法。WebViewClient类主要是用来帮助WebView处理各种通知、请求事件的,这其中有一些常用方法:

(1) shouldOverrideUrlLoading(WebView view, String url),当加载的网页需要重定向的时候就会回调这个函数。

参数1:WebView对象

参数2:需要加载的url地址

返回值:return true意味着主程序接管网页加载,让我们自己操作,如果返回false让webview自己处理。

(2) onPageStarted(WebView view, String url, Bitmap favicon), 开始加载页面的回调;

(3) onPageFinished(WebView view, String url), 加载完成的回调。

当我们需要重写上述方法时需要调用WebView中setWebViewClient (WebViewClient client)方法,下面在原来代码更改为用Webview控件显示网页,代码如下:

public class MainActivity extends Activity {

WebView vb;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

vb = (WebView) findViewById(R.id.webView1);

//设置Webview

vb.setWebViewClient(new WebViewClient(){

@Override

//重写shouldOverrideUrlLoading方法

public boolean shouldOverrideUrlLoading(WebView view, String url) {

return false;

}

});

vb.loadUrl("http://www.baidu.com");

}

}

运行效果如下:

二、WebView加载HTML字符串

有时候我们的webview可能只是html片段,而不是一个完整的网页,事实上绝大多数时候都是如此,完整的网页无需做成应用,而直接在浏览器访问。

这种情况我们使用 LoadData 或者 loadDataWithBaseURL方法,后者用的最多,这里需要调用WebView中的loadDataWithBaseURL(String baseUrl, String data, String mimeType, String encoding, String historyUrl)方法:

参数1:作为该网页的base page。可设置为null。

参数2:html字符串

参数3:类型,html数据需要设置为“text/html”

参数4:字符集,如果有中文需要设置为“utf-8”

参数5:历史网页的url,可设置为null。

下面是一个简单的实例,代码如下:

public class MainActivity extends ActionBarActivity {

WebView wb;

String data = "" +

"" +

"敢问路在何方,路就在脚下" +

"";

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

wb = (WebView) findViewById(R.id.webView1);

wb.loadDataWithBaseURL(null, data, "text/html", "utf-8", null);

}

}

运行结果如下:

三、WebView中JavaScript与Andorid中java方法互调

随着h5在移动端的普及,移动端对webview的使用越来越平凡,有的界面也不仅仅局限于网页的显示,很多时候就要涉及到webview与javascript代码之间的交互,这对于移动端工程师和web端工程师都是一个挑战,下面来总结下它们之间的交互和注意事项。

先说JavaScript中调用android代码,默认情况下,从WebView的界面中无法触发html中的JavaScript脚本,我们需要使能JavaScript功能,这样WebView才有能力处理html中的JavaScript脚本。使能JavaScript对应的方法为setJavaScriptEnabled(boolean flag),该方法并不是WebView类中方法,它的使用过程如下:

(1)调用WebView中getSettings()方法获取WebSettings对象;

(2)调用WebSettings对象的实例方法setJavaScriptEnabled。

当参数设置为true时,表示使能JavaScript。

要想完成JavaScript调用android代码,还需介绍一个方法,WebView类中的addJavascriptInterface(Object object, String name),

参数1:供JavaScript调用的对象

参数2:在JavaScript中使用的名字

该方法是这里的重点,将一个java对象绑定到一个javascript对象中,javascript对象名就是interfaceName,作用域是Global。

我们可以在JavaScript中调用Java中的函数的步骤如下:

(1)创建WebView对象

(2)使能WebView对象的JavaScript功能

(3)创建类,该类作为JavaScript调用Java代码的接口

(4)在该类中暴露方法,供JavaScript调用,注意:API 17之后的版本需 要添加注解@JavascriptInterface。

(5)将接口类对象添加给WebView

addJavascriptInterface(Object, String)

(6)在html中添加JavaScript代码,调用Java对象中暴露的方法。

具体代码如下:

MainActivity:

public class MainActivity extends ActionBarActivity {

WebView wb;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

wb = (WebView) findViewById(R.id.webView1);

//使能JavaScript

wb.getSettings().setJavaScriptEnabled(true);

//绑定对应java对象到JavaScript

wb.addJavascriptInterface(new MyJavaScript(this), "MyJavaScript");

//加载本地文件

wb.loadUrl("file:///android_asset/my.html");

}

}

本地文件放在asset目录下,调用时路径格式为file:///android_asset/xx。

自定义JavaScript调用java的类:

public class MyJavaScript {

Context context;

public MyJavaScript(Context context) {

super();

this.context = context;

}

//供JavaScript调用的java方法,此处须与JavaScript中script标签中调用的方法名一致

public void ShowToast(String str){

Toast.makeText(context, str, Toast.LENGTH_SHORT).show();

}

}

本地HTML文件:

//输出内容有中文时加上

type="button" id="button1" onclick="callAndroid();" >

点击js调用java代码

该HTML文件显示的页面只有一个“点击js调用java代码”的按钮,点击该按钮后会触发script中定义的点击事件方法callAndroid(),该方法会调用java代码中相对应的方法,从而实现JavaScript中调用android代码。运行效果如下,点击按钮后会弹出一个Toast。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭