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

制作的app嵌入h5

App中嵌入H5页面是一种常见的移动端开发方式,H5网页作为一种常见的Web界面设计技术,在移动端也是非常流行的。本文将从原理和详细介绍两个方面来进行讲解。

一、原理

App中嵌入H5页面的原理其实很简单,就是利用WebView控件,将一个H5网页嵌入到App中作为其中的一个页面。WebView控件是Android平台自带的控件之一,可以用于在应用中显示网页和HTML的内容。

在Android平台上,开发者可以通过搭建一个WebView来显示一个H5页面。开发者应该熟悉如何使用WebView,它可以让你在应用程序中显示一个网页。

在安卓中,使用WebView控件来嵌入H5页面,主要的步骤包括:

1. 创建一个activity,并在这个activity的布局文件中定义一个WebView控件。

2. 像一个网页一样加载目标H5页面和数据。

3. 接收H5页面传递的调用,并对此做出响应。

相比于安卓平台,IOS平台上的WebView常用于显示进度条,处理JavaScript交互和传递数据等工作。

二、详细介绍

1. 创建一个activity

一般需要至少一个布局文件和一个活动类,布局文件显式地定义出WebView控件,活动类就负责将之生成与嵌入。

布局文件:

```xml

android:orientation="vertical"

android:layout_width="match_parent"

android:layout_height="match_parent">

android:id="@+id/webView"

android:layout_width="fill_parent"

android:layout_height="fill_parent"/>

```

2. H5页面加载

无论是Android平台还是iOS平台,都需要为WebView控件设置一定的属性,以便正确地显示H5页面,WebApp页面包括CSS、JS和HTML文件。为了完成页面加载,我们需要加载所有文件并将它们显示在WebView中。在Android中,我们可以使用loadUrl()方法,该方法将相应的URL传递给该方法,以便加入WebView进行处理。在IOS中,我们可以使用loadRequest()方法,该方法将包含所有文件的NSURL传递给该方法,以便加入WebView进行处理。

在Android平台上:

```java

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

webView.getSettings().setJavaScriptEnabled(true); //设置WebView属性,能够执行JavaScript脚本

webView.loadUrl("file:///android_asset/h5/index.html"); //WebApp页面的URL

```

在iOS平台上:

```Swift

let webView = WKWebView(frame: self.view.bounds)

let url = Bundle.main.url(forResource: "index", withExtension: "html", subdirectory: "h5")!

webView.loadFileURL(url, allowingReadAccessTo: url)

self.view.addSubview(webView)

```

3. 接收H5页面传递的调用

H5页面与原生App之间的交互,其实是通过JavaScript代码实现交互的。在WebView之间传递数据,使用的是指定的JavaScript方法。在Android平台上,使用WebView控件可以添加一个JavaScript的接口,以在WebView中注册一个方法,以便可以通过JavaScript调用。在iOS平台上,您可以通过重定向或JavaScript重新调用来调用您的Objective-C或Swift代码。再次,这些所有代码都在UIWebViewDelegate或WKScriptMessageHandler协议中实现。

在Android平台上:

```java

webView.addJavascriptInterface(new Object(){

@JavascriptInterface

public void showToast(String s){

Toast.makeText(MainActivity.this,s,Toast.LENGTH_SHORT).show();

}

},"android");

```

在iOS平台上:

```Swift

class ViewController: UIViewController, WKScriptMessageHandler {

override func viewDidLoad() {

super.viewDidLoad()

// 创建WKWebViewConfiguration

let config = WKWebViewConfiguration()

// 创建WKUserContentController

let userContentController = WKUserContentController()

// 将WKUserContentController赋值给WKWebViewConfiguration

config.userContentController = userContentController

// 注册要在JS中调用的方法

userContentController.add(self, name: "showAlert")

// 创建WKWebView

let webView = WKWebView(frame: self.view.bounds, configuration: config)

// 创建URL

let url = Bundle.main.url(forResource: "index", withExtension: "html", subdirectory: "h5")!

// 加载URL

webView.loadFileURL(url, allowingReadAccessTo: url)

// 手动添加约束

webView.translatesAutoresizingMaskIntoConstraints = false

self.view.addSubview(webView)

webView.topAnchor.constraint(equalTo: self.view.safeAreaLayoutGuide.topAnchor).isActive = true

webView.leftAnchor.constraint(equalTo: self.view.safeAreaLayoutGuide.leftAnchor).isActive = true

webView.bottomAnchor.constraint(equalTo: self.view.safeAreaLayoutGuide.bottomAnchor).isActive = true

webView.rightAnchor.constraint(equalTo: self.view.safeAreaLayoutGuide.rightAnchor).isActive = true

}

//在此触发 对象桥接 WKScriptMessageHandler

func userContentController(_ userContentController: WKUserContentController, didReceive message: WKScriptMessage) {

if message.name == "showAlert" {

let alertController = UIAlertController(title: "来自JS的提示", message: "Hello, World!", preferredStyle: .alert)

let okAction = UIAlertAction(title: "OK", style: .default, handler: nil)

alertController.addAction(okAction)

self.present(alertController, animated: true, completion: nil)

}

}

}

```

以上内容,即为App中嵌入H5页面的原理和详细介绍。总之,利用WebView控件,开发者完全可以将现有的H5页面嵌入到App中,且其实现方法也并不难。对于大多数互联网公司、电商公司等需要快速迭代的业务场景来说,这种开发方式有众多的优点,如高效、快速、易维护等等。


相关知识:
怎么制作h5游戏app
随着移动互联网的发展,越来越多的游戏开发者开始探索如何将游戏移植到移动端,尤其是h5游戏因其体积小、跨平台性等优势被越来越广泛地采用。那么,如何制作一款h5游戏app呢?下面我们将从原理和详细介绍两个方面来进行讲解。一、原理h5游戏app的原理主要是基于W
2023-05-26
原生app与h5开发搭建
随着移动互联网的不断发展,原生App和H5开发逐渐成为了手机应用程序的两种主要开发方式。本篇文章将从原理和详细介绍两方面分别介绍原生App和H5开发的搭建方法。一、原生App搭建原生App是指针对某个特定设备和操作系统使用本地编程语言进行编写,可以直接安装
2023-05-26
用h5做的直播app
随着网络带宽越来越大,人们的需求也不断增加,传统视频直播方式已经不能满足人们的需求。而 HTML5 作为一种跨平台开发技术,因为具有跨平台、低成本、易开发等优点,成为了直播行业新的热门技术。下面我将为大家介绍基于 HTML5 的直播 App 开发原理和详细
2023-05-26
贵港h5开发app
在互联网时代,移动端应用程序(APP)已经成为生活中不可缺少的一部分。H5页面也越来越流行,那么如何通过H5开发来实现APP呢?本文将详细介绍贵港H5开发APP的原理和方法。一、什么是H5开发APPH5是指HTML5,是一种新一代的网页制作标准。H5技术可
2023-05-25
h5做出来的app需要发布到商城吗
H5开发技术可以帮助我们开发基于HTML5、CSS3、JS等技术构建的移动应用点,而相比于原生应用, H5开发的应用不需要下载安装,直接在网页中进行使用,这使得H5应用的分发和传播变得极为方便。不过,如果我们想要让H5应用更好地为用户服务,甚至盈利,我们就
2023-05-25
h5自行打包为app
H5(HTML5)是一种基于网页标准的技术,可以实现跨平台应用程序的编写。H5技术可以在各种设备,包括手机,平板电脑和电脑上使用,因此,它已成为移动应用程序开发的重要组成部分。H5应用程序在浏览器中运行,但是,有时候我们需要将它打包成一个独立的应用程序,以
2023-05-25
h5网站生成 app
近年来,移动应用开发已经成为热门的话题,而H5网站转为APP的话题也逐渐被人们关注。H5网站生成APP的原理实际上就是将H5网站打包成一款移动应用,让它能够正常执行,缺点是不能完全利用原生APP的优势特性,比如说高性能、在线调试、和处理复杂交互等等。下面我
2023-05-25
h5生成软件app
H5生成软件App是一款可以将HTML5代码转化为原生APP的软件。通俗来说,就是可以将我们在网页上所编写的代码直接转化为手机应用程序。这个软件的原理其实也很简单,只要将HTML5代码嵌入到Webview控件中,就可以将我们所编写的代码直接呈现在移动端上面
2023-05-25
h5打包app对接sdk
随着移动互联网的发展,越来越多的Web开发者开始关注如何将自己的Web应用变成一款手机APP。而H5打包App成为了简化开发流程和成本的一种方案,成为了越来越多开发者的首选。但是,在将H5应用打包成App的过程中,需要对接各种SDK来实现更多的功能,比如分
2023-05-25
h5打包app含谷歌浏览器
在移动互联网时代,许多网站和应用都已经开始开发移动端版本。而对于一些网站或应用来说,开发一个原生的移动应用是一个比较耗时的过程。因此,将网站或应用打包成为移动应用已成为一种主流的解决方案。本文将详细介绍如何将一个基于HTML5的网站打包成移动应用,并且包含
2023-05-25
app之h5app列表组件封装
H5 App是一种基于HTML5技术在移动平台上运行的应用程序,而列表组件是H5 App中非常常用的的一种组件。因此,为方便H5 App开发者使用列表组件,在此我们介绍一种常见的H5 App列表组件封装方式。该列表组件封装方式主要基于Vue.js,旨在提供
2023-05-25
h5 app制作工具
随着移动互联网的发展,H5技术在移动应用开发中得到越来越广泛的应用。H5技术可以快速实现跨平台应用的开发,从而提高开发效率,减少开发成本。而在H5应用开发中,H5 app制作工具的出现,更是进一步促进了H5技术的发展和应用。H5 app制作工具是一种较为普
2023-05-25
©2015-2021 一门APP yimenapp.com  川公网安备 51019002001185号 蜀ICP备17005078号-3