APP封装从一门开始
一门提供APP封装底层开发框架,一键在线APP封装,200+原生APP模块,2000+JS映射接口按需自助封装

封装h5为app

在互联网时代,移动应用的市场越来越火爆。不仅仅是大型APP,像小程序、H5应用这种轻量级的应用越来越受到用户的欢迎。但是,由于不是原生应用,H5应用并不能和原生应用有同等的使用效果。封装H5应用为原生应用则可以弥补这一短板,本文将介绍封装H5应用为原生应用的原理及详细步骤。

一、封装H5应用的原理

封装H5应用为原生应用的原理其实很简单,这里主要分两步:

1. 将H5应用解压缩到本地目录中,并使用Webview调用index.html文件;

2. 使用桥接方式,将原生App和JS之间的交互打通。

第一步使用的是Webview技术,它是Android系统中的一种组件,可以在应用内加载网页并显示出来。我们只需要把H5应用的全部静态文件打包成一个zip压缩包,在App中解压缩,然后使用WebView控件打开H5应用中的index.html文件即可。

第二步则需要从两个应用技术角度考虑:原生应用和H5应用之间要如何通信?具体来说,就是如何实现原生App调用H5应用,以及H5应用回调原生App的功能。这一步主要实现思路是在原生App中内置一个JavaScript桥接文件,通过该文件,JS可以直接读取原生App的接口,另一方面,原生App也可以通过该文件直接调用H5中的js方法。

二、封装H5应用的具体步骤

下面详细介绍一下,封装H5应用为原生应用的具体步骤。

1. H5应用的打包和解压

我们首先需要将H5应用的代码打包成zip文件,命名为“app.zip”,然后将该zip文件复制到App的assets目录下。当App启动时,首先从资源目录中读取app.zip文件,并解压到磁盘上,如下所示:

```

public class MainActivity extends AppCompatActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//复制app.zip到sdcard根目录下,并解压到app目录中

String zipPath = Environment.getExternalStorageDirectory().getAbsolutePath() + "/app.zip";

String appPath = getApplicationContext().getFilesDir().getAbsolutePath();

FileUtils.copyFile(zipPath, appPath + "/app.zip"); //复制

ZipUtils.unZip(appPath + "/app.zip", appPath + "/app"); //解压

}

}

```

在解压之后,我们需要将H5应用的入口文件(index.html)通过Webview调用出来,如下所示:

```

public class MainActivity extends AppCompatActivity {

private WebView mWebView;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//找到WebView控件,并加载index.html

mWebView = (WebView) findViewById(R.id.web_view);

String appPath = getApplicationContext().getFilesDir().getAbsolutePath();

mWebView.loadUrl("file://" + appPath + "/app/index.html");

}

}

```

2. 原生App和H5应用之间的交互

下面我们将介绍如何实现App和H5应用之间的交互。

首先,创建一个JsBridge类,这个类继承自WebViewClient。按照常规做法,在加载H5应用时用该类覆盖掉WebView的默认实现。我们可以通过这个桥接文件,在App和H5应用之间建立双向通信通道。下面的示例代码演示了如何将原生App的功能暴露给JS:

```

public class JsBridge extends WebViewClient {

private WeakReference mActivityRef;

//原生App调用H5应用

public void callJs(WebView webView, String jsFunc, String message) {

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {

webView.evaluateJavascript("javascript:" + jsFunc + "('" + message + "')", null);

} else {

webView.loadUrl("javascript:" + jsFunc + "('" + message + "')");

}

}

//H5应用调用原生App

public boolean shouldOverrideUrlLoading(WebView view, String url) {

if (url.startsWith("jsbridge://")) {

String[] urls = url.split("//");

String message = urls[1];

String func = urls[2];

callNative(func, message); //调用原生App的方法

return true;

}

return super.shouldOverrideUrlLoading(view, url);

}

//调用原生App的方法

private void callNative(String func, String message) {

Activity activity = mActivityRef.get();

if (activity != null) {

if ("showToast".equals(func)) {

Toast.makeText(activity, message, Toast.LENGTH_SHORT).show();

} else if ("callPhone".equals(func)) {

Intent intent = new Intent(Intent.ACTION_DIAL, Uri.parse("tel:" + message));

activity.startActivity(intent);

} else if ("openUrl".equals(func)) {

Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(message));

activity.startActivity(intent);

}

}

}

}

```

上面代码中, 原生App和H5应用中的通讯协议采用“jsbridge://”形式,其中jsbridge前缀为自定义协议的名称。H5应用通过window.location.href属性调用原生App的接口,调用格式为:

```

window.location.href='jsbridge://message/callNative?abc'

```

接下来,我们在MainActivty类中将JsBridge类作为WebView的Client实现,并注册全局的桥接对象:

```

public class MainActivity extends AppCompatActivity {

private WebView mWebView;

private JsBridge mJsBridge = new JsBridge(this);

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//找到WebView控件,并加载index.html

mWebView = (WebView) findViewById(R.id.web_view);

mWebView.getSettings().setJavaScriptEnabled(true);

mWebView.setWebViewClient(mJsBridge);

mWebView.addJavascriptInterface(new JsApi(this), "JsApi");

String appPath = getApplicationContext().getFilesDir().getAbsolutePath();

mWebView.loadUrl("file://" + appPath + "/app/index.html");

}

}

```

在上面的代码中,我们使用addJavascriptInterface方法将原生功能依附到JS的window对象上,这样就可以在JS中直接调用该接口了。JsApi类的源代码如下:

```

public class JsApi {

private Activity mActivity;

public JsApi(Activity activity) {

mActivity = activity;

}

@JavascriptInterface

public void showToast(String message) {

Toast.makeText(mActivity, message, Toast.LENGTH_SHORT).show();

}

@JavascriptInterface

public void openUrl(String url) {

Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url));

mActivity.startActivity(intent);

}

@JavascriptInterface

public void share(String message) {

Intent shareIntent = new Intent(Intent.ACTION_SEND);

shareIntent.setType("text/plain");

shareIntent.putExtra(Intent.EXTRA_TEXT, message);

mActivity.startActivity(Intent.createChooser(shareIntent, "Share this"));

}

}

```

三、总结

本文主要介绍了如何将H5应用封装为原生App,主要包括两步:将H5应用解压缩到本地,并使用Webview调用index.html文件;使用桥接方式,将原生App和JS之间的交互打通。如果你正在开发一些轻量级应用,H5应用的封装为原生App则是一个有效的方案,不仅使得用户使用起来更加方便,也增加了应用的流行度。


相关知识:
中山h5开发app
H5开发APP是一种基于HTML5,通过WebView嵌入到APP中的开发方式,是移动互联网发展过程中的一种架构,它将传统的原生APP开发方式和Web开发方式结合起来,具有开发成本低、开发周期短、兼容性好、易于维护升级等特点,已经成为越来越多APP开发者的
2023-05-26
秀米app手机端如何制作h5
秀米是一款非常受欢迎的在线H5制作工具,用户可以经过简单的操作,在该工具中制作出丰富多彩的H5页面内容。不仅如此,秀米的移动端app同样也非常受欢迎,用户可以通过秀米手机端app轻松快捷地创建H5页面。下面我们就来看看秀米app手机端如何制作H5。1.打开
2023-05-26
哪些app是h5开发
H5是HTML5的简称,是一种优秀的前端技术。它使得在移动设备中浏览器的使用和显示与桌面浏览器十分相似,同时也为手机浏览器的应用开发提供了更多的设计元素。在app的开发中,H5也有着广泛的应用。下面我将介绍一些H5开发的app。1.高德地图高德地图是国内最
2023-05-26
可以在线付款的h5制作app
随着移动互联网的发展和普及,很多企业和个人开始转向H5制作APP的领域进行开发。H5 APP不需要安装,随时随地可以访问,具有跨平台和易于维护等优点,因此被越来越多的开发者所青睐。在H5制作APP中,可以集成在线付款的功能,方便用户进行支付,本文将介绍一些
2023-05-26
hbuilder将h5打包app
HBuilder是一款基于HTML5开发的构建APP和微信小程序的集成开发环境。它支持多个平台的打包,包括Android、iOS和Windows等,使开发者能够在一个平台上快速、高效地开发多个平台的应用程序。本篇文章将介绍如何使用HBuilder将H5网站
2023-05-25
h5做app和原生app有什么区别
H5作为一种开发技术,可以用来制作移动应用,常被称为“H5 APP”。与之相对的,原生APP指的是使用原生开发语言(如Java、Kotlin等)开发的应用程序。这两种应用程序在开发、运行以及用户体验方面有一些不同之处。1. 开发成本开发H5 APP相对来说
2023-05-25
h5制作app什么软件
H5是一种可以在移动端运行的网页技术,可以在移动端上开发网页应用程序,让用户可以像打开原生应用一样来打开它们。因为H5具有跨平台和强大的可访问性,所以许多人希望使用H5技术来制作移动应用程序。如果你想使用H5来制作移动应用程序,那么你需要了解的必须有以下内
2023-05-25
h5源码可以做成app吗
HTML5,也就是超文本标记语言第五版,是Web技术领域的一个重要方向,它不仅可以用于网页制作,而且还可以用于开发移动应用。HTML5技术的主要优点是灵活性高、跨平台、可维护性强等,这些特点也是确定HTML5应用程序在移动应用开发领域上非常有潜力的原因。那
2023-05-25
h5页面页面制作app
随着智能手机的普及,移动互联网已经逐渐成为人们日常生活中不可或缺的一部分。随之而来的是,移动应用程序的数量也不断增长。为了更好地满足用户需求,移动应用程序的开发方式也在不断变革。其中,利用H5页面制作APP的方式得到了广泛应用。本文将为大家介绍H5页面制作
2023-05-25
h5开发app的优点
H5开发App是指通过HTML5技术开发出的原生应用,可在移动设备上运行,而且具有原生应用的基本功能和用户体验。在当今移动应用市场中,H5应用开发模式越来越流行。本文将详细介绍H5开发App的优点。一、跨平台性H5开发App基于web技术,不同于传统原生开
2023-05-25
h5画报制作模板app
随着移动互联网的发展,越来越多的人开始使用手机和平板电脑来浏览网络画报。因此,有一个方便快捷的工具能够帮助用户制作个性化的画报就显得非常重要。本文将介绍一款H5画报制作模板App的原理和详细使用介绍。H5文本编辑器是一种可以帮助用户创建风格独特的H5文档、
2023-05-25
h5封装app不能上架
随着移动互联网的快速发展,手机应用程序成为人们日常生活中不可或缺的一部分。而HTML5技术的逐渐成熟,更加方便了开发者和公司在手机应用上的运用。H5封装App是指利用WebView渲染引擎,将H5页面进行封装,形成iOS或Android App,使其在手机
2023-05-25
©2015-2021 一门APP yimenapp.com  川公网安备 51019002001185号 蜀ICP备17005078号-3