android使用webwiew载入页面使用示例(Hybrid App开发)
android使用webwiew载入页面使用示例(Hybrid App开发)
发布时间:2016-12-28 来源:查字典编辑
摘要:HybridApp是混合模式应用的简称,兼具NativeApp和WebApp两种模式应用的优势,开发成本低,拥有Web技术跨平台特性。目前大...

Hybrid App 是混合模式应用的简称,兼具 Native App 和 Web App 两种模式应用的优势,开发成本低,拥有 Web 技术跨平台特性。目前大家所知道的基于中间件的移动开发框架都是采用的 Hybrid 开发模式,例如国外的 PhoneGap、Titanium、Sencha,还有国内的 AppCan、Rexsee 等等。Hybrid App 开发模式正在被越来越多的公司和开发者所认同,相信将来会成为主流的移动应用开发模式。

Hybrid App 融合 Web App 的原理就是嵌入一个WebView组件,可以在这个组件中载入页面,相当于内嵌的浏览器,代码如下:

复制代码 代码如下:

import android.app.Activity;

import android.os.Bundle;

import android.webkit.WebSettings;

import android.webkit.WebView;

public class AActivity extends Activity{

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

// 创建WebView

WebView webView= new WebView(this);

// 切换到内容视图

setContentView(webView);

// 获取WebView配置

WebSettings ws = webView.getSettings();

// 启用JavaScript

ws.setJavaScriptEnabled(true);

// 载入assets目录下的一个页面

webView.loadUrl("file:///android_asset/www/BoBox/index.html");

}

}

还有另一种引入方式是在布局文件中添加 WebView 组件,代码如下:

复制代码 代码如下:

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:orientation="vertical"

android:layout_width="fill_parent"

android:layout_height="fill_parent">

<WebView

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:id="@+id/webview"

/>

</LinearLayout>

复制代码 代码如下:

import android.app.Activity;

import android.os.Bundle;

import android.webkit.WebSettings;

import android.webkit.WebView;

public class BActivity extends Activity{

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.webview);

// 查找WebView

WebView webView = (WebView) findViewById(R.id.webview);

// 获取WebView配置

WebSettings ws = webView.getSettings();

// 启用JavaScript

ws.setJavaScriptEnabled(true);

// 在载入assets目录下的一个页面

webView.loadUrl("file:///android_asset/www/index.html");

}

}

WebView 还有一个非常重要的方法——addJavascriptInterface,可以用来实现 Java 程序和 JavaScript 程序的相互调用,代码如下:

复制代码 代码如下:

webView.addJavascriptInterface(new Object(){

public void clickOnAndroid(){

mHandler.post(new Runnable(){

public void run(){

webView.loadUrl("javascript:wave()");

}

});

}

}, "demo");

页面代码如下:

复制代码 代码如下:

<script>

function wave() {

document.getElementById("id").innerHTML = "Hello World!";

}

</script>

</head>

<body>

<div>

<a href="#" id="demo">Click Me</a>

</div>

</body>

</html>

这样,当你点击页面上 Click Me 按钮的时候就会调用 Java 代码中的 clickOnAndroid 函数,clickOnAndroid 函数中又调用页面中的 wave 方法。需要注意的是:这个接口在 Android 2.3 版本的模拟器中运行会导致 WebView 崩溃,目前还没有修复。这是一个非常简单的演示 Java 和 JavaScript 相互调用的例子,在实际应用中可以在页面调用的 clickOnAndroid 函数中再调用摄像头、通讯录、通知提醒等设备功能。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新安卓软件开发学习
热门安卓软件开发学习
编程开发子分类