我的编程空间,编程开发者的网络收藏夹
学习永远不晚

H5项目如何开发iOS插件功能

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

H5项目如何开发iOS插件功能

这篇文章主要为大家展示了“H5项目如何开发iOS插件功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“H5项目如何开发iOS插件功能”这篇文章吧。

HBuilder用来写H5项目,Xcode用来写iOS原生的插件,我所需实现的是,在H5页面点击打印,运行iOS原生插件来实现连接蓝牙打印机并打印出获取的内容。

首先去HBuilder文档上,下载HBuilder离线打包iOS版SDK,运行HBuilder-Hello,在HBuilder-Hello项目基础上开始进行原生插件开发。

HTML5+ 基座扩展采用三层结构,JS层、PluginBridge层和Native层。 三层功能分别是:
JS层: 在Webview页面调用,触发Native层代码,获取执行结果。 PluginBridge层: 将JS层请求进行处理,触发Native层扩展插件代码。
Native层: 插件扩展的平台原生代码,负责执行业务逻辑并执行结果返回到请求页面。

先来注册下对应关系
修改PandoraAPI.bundle中feature.plist文件,在其中添加JS插件别名和Native插件类的对应关系,SDK基座会根据对应关系查找并生成相应的Native对象并执行对应的方法。

plugintest为你所要扩展的插件类的类名,在iOS中创建plugintest类,并继承于PGPlugin,在.h中导入PGPlugin.h,PGMethod.h

 #include "PGPlugin.h"
  #include "PGMethod.h"

若需要静态库的话直接吧.a和.h文件拖到项目中就可以了,native中的方法分同步和异步方法,我在这里只介绍异步方法

- (void)PluginTestFunctionArrayArgu:(PGMethod *)msg
{
    NSArray *pArray = [NSArray array];    if (msg)
    {        //CallBackid 异步方法的回调id,H5+ 会根据回调ID通知JS层运行结果成功或者失败
        NSString *cdId = [msg.arguments objectAtIndex:0];        //用户的参数会在第二个参数传回,可以按照Array方式传入
        pArray = [msg.arguments objectAtIndex:1];
        NSLog(@"cdId: %@    pArray: %@",cdId,pArray);        // 如果使用Array方式传递参数
        NSString *pResultString = [NSString stringWithFormat:@"%@ %@ %@ %@ %@ %@ %@",[pArray objectAtIndex:0],[pArray objectAtIndex:1], [pArray objectAtIndex:2],[pArray objectAtIndex:3],[pArray objectAtIndex:4], [pArray objectAtIndex:5],[pArray objectAtIndex:6]];
        NSLog(@"pResultString: %@",pResultString);        //可以直接调用所导入的静态库里面的方法
        NSString *UUID = [ZQDeviceSDK Prn_GetPortList:1];
        NSString *port = [UUID stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];
        [self startPrintText:pArray andUUID:port];        // 运行Native代码结果和预期相同,调用回调通知JS层运行成功并返回结果
         PDRPluginResult *result = [PDRPluginResult resultWithStatus:PDRCommandStatusOK messageAsString:pResultString];        // 如果Native代码运行结果和预期不同,需要通过回调通知JS层出现错误,并返回错误提示//        PDRPluginResult *resultError = [PDRPluginResult resultWithStatus:PDRCommandStatusError messageAsString:@"出错了!"];
        //通知JS层Native层运行结果,JS Pluginbridge会根据cbid找到对应的回调方法并触发
       [self toCallback:cdId withReslut:[result toJSONString]];
    }
}

在js中的函数

document.addEventListener( "plusready",  function(){  // 声明的JS“扩展插件别名”
     var _BARCODE = 'plugintest',B = window.plus.bridge;     var plugintest ={         // 声明异步返回方法
         // 通知Native层plugintest扩展插件运行”PluginTestFunction”方法
        //参数为所需传入原生的参数
         PluginTestFunctionArrayArgu : function (Argus, successCallback, errorCallback ){             var success = typeof successCallback !== 'function' ? null : function(args) 
              {
                  successCallback(args);
              },
              fail = typeof errorCallback !== 'function' ? null : function(code) 
              {
                  errorCallback(code);
              };
              callbackID = B.callbackId(success, fail);              //这里写上原生中的异步方法名
              return B.exec(_BARCODE, "PluginTestFunctionArrayArgu", [callbackID, Argus]);
         }   
      window.plus.plugintest = plugintest;
 }, true );

在H5中调用的代码

plus.plugintest.PluginTestFunctionArrayArgu( printData, function( result ) {
                 mui.alert( result );
                },function(result){
                 mui.alert(result)
                 });

大致的开发流程就值这个样子,其实真正麻烦的并是不代码而是IDE的各种调试..
下面就是把H5项目导入Xcode来实现离线打包了,在项目的manifest.json中,修改appid,使其与Xcode中的appid一致,Version和Build对应version下的name和code

将manifest.json中的中文注释全部删除,然后把H5项目导入到Pandora下的www目录中,记住,把项目下的所有文件导入到www下,而不是项目文件夹直接导入到www下,那样运行会打不开App。

把www上一级的文件夹名称改为Appid一致的名称,修改图标可以把图标放入HBuilder中可以生成相应尺寸的图标..这点儿用着非常亲民..之前iOS开发都是去找美工要的..接着修改项目名称等我就不再一一说了。

以上是“H5项目如何开发iOS插件功能”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

H5项目如何开发iOS插件功能

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

下载Word文档

猜你喜欢

Sphinx搜索的扩展插件与定制化开发实践(如何为Sphinx开发扩展插件和定制功能?)

Sphinx扩展插件和定制化开发指南,详解扩展插件的创建和安装,以及定制化开发的实践。开发者可以通过扩展Sphinx的核心功能和直接修改源代码来增强其搜索功能,以满足特定需求。扩展插件相对易开发,而定制化开发则需要对Sphinx源代码有深入了解。根据具体要求,可选择适合的开发方式,优先考虑扩展插件,仅在必需时进行定制化开发。
Sphinx搜索的扩展插件与定制化开发实践(如何为Sphinx开发扩展插件和定制功能?)
2024-04-02

Elasticsearch分布式搜索引擎的插件开发与扩展(如何为Elasticsearch开发并扩展新的插件功能?)

Elasticsearch插件开发与扩展简介Elasticsearch是一个分布式搜索引擎,通过插件扩展和定制以满足特定需求。本文介绍如何开发和扩展Elasticsearch插件功能,包括插件架构、开发步骤、扩展功能类型、安装与管理,以及最佳实践。插件架构采用模块化设计,每个插件包含自己的元数据和扩展点。开发插件需实现扩展点,例如自定义分析器或查询处理器。插件可以扩展Elasticsearch功能,包括添加自定义分析器、增强查询处理、扩展聚合、添加自定义API和集成第三方库。开发时应遵守Elasticse
Elasticsearch分布式搜索引擎的插件开发与扩展(如何为Elasticsearch开发并扩展新的插件功能?)
2024-04-02

如何在PHP项目中实现邮件发送和通知功能?

如何在PHP项目中实现邮件发送和通知功能?在当今互联网时代,邮件已成为人们日常生活中不可或缺的一部分。对于PHP开发者来说,实现邮件发送和通知功能在许多项目中是非常常见的需求。本文将介绍如何在PHP项目中实现邮件发送和通知功能,并提供一些实
如何在PHP项目中实现邮件发送和通知功能?
2023-11-02

asp.net如何开发微信派发现金红包/H5网页抢红包功能

这篇文章将为大家详细讲解有关asp.net如何开发微信派发现金红包/H5网页抢红包功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、网页版抢红包功能,1、前端先做好抢红包的页面;3、后台配置微信公众号
2023-06-14

如何JavaScript项目中实现一个input组件功能

这篇文章主要介绍了如何JavaScript项目中实现一个input组件功能,此处通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考价值,需要的朋友可以参考下:Java的特点有哪些Java的特点有哪些1.Java语言作为静态面
2023-06-06

如何为记账系统添加自定义插件功能 - 使用PHP开发自定义插件的方法

随着业务的发展和需求的多样化,很多企业和个人都选择使用记账系统来管理财务和记账工作。然而,随着时间的推移,记账系统的功能可能无法完全满足用户的需求,这就需要我们为记账系统添加自定义插件功能,以实现个性化定制和功能扩展。本文将介绍如何使用PH
2023-10-21

如何在JavaWeb项目中实现文件压缩下载功能

本篇文章为大家展示了如何在JavaWeb项目中实现文件压缩下载功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。具体代码如下所示://文件名称 String[] names={"one.jpg
2023-05-31

在Java项目中如果发送http请求实现文件上传功能

在Java项目中如果发送http请求实现文件上传功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。具体代码如下所示:package wxapi.WxHelper; import
2023-05-31

Win7系统最近使用的项目在哪如何开启最近使用的项目功能

刚从XP升级到Win7的用编程户对于很多设置的变动一定觉得很迷惑,其中一个js就是Win7系统最近使用的项目在哪呢?其实在默认状况下这个功能在Win7系统中是关闭的。下面系统之家小编就为大家介绍一下如何开启Win7系统"最近使用的项目"功能
2023-06-06

如何在PHP项目中实现日历功能和事件提醒?

如何在PHP项目中实现日历功能和事件提醒?在开发Web应用程序时,日历功能和事件提醒是常见的需求之一。无论是个人日程管理、团队协作,还是在线活动安排,日历功能都可以提供便捷的时间管理和事务安排。在PHP项目中实现日历功能和事件提醒可以通过以
如何在PHP项目中实现日历功能和事件提醒?
2023-11-02

golang Websocket教程:如何开发在线文件传输功能

Golang Websocket教程:如何开发在线文件传输功能引言:随着互联网的快速发展,文件传输成了人们在网络上常常面临的需求。而利用Websocket技术,我们可以轻松地实现在线文件传输功能。本文将介绍如何使用Golang开发一个基于W
golang Websocket教程:如何开发在线文件传输功能
2023-12-17

如何使用Python开发游戏运行脚本成功调用大漠插件

这篇文章将为大家详细讲解有关如何使用Python开发游戏运行脚本成功调用大漠插件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、搭建python开发环境(注意:想要使用大漠插件,必须使用32位的pyth
2023-06-25

在Java项目中使用fileupload组件如何实现一个文件上传功能

本篇文章给大家分享的是有关在Java项目中使用fileupload组件如何实现一个文件上传功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。使用fileupload组件的原因:
2023-05-31

如何利用MySQL和C++开发一个简单的邮件发送功能

如何利用MySQL和C++开发一个简单的邮件发送功能摘要:本文将介绍如何以MySQL数据库为基础,使用C++编程语言开发一个简单的邮件发送功能。文章主要包括以下几个方面的内容:数据库设计、C++代码实现和邮件发送功能的实现。一、数据库设计在
2023-10-22

在Java项目中使用WebUploader如何实现一个文件上传功能

本篇文章为大家展示了在Java项目中使用WebUploader如何实现一个文件上传功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。之前自己写小项目的时候也碰到过文件上传的问题,没有找到很好的解决方
2023-05-31

在java项目中使用Demo如何实现一个文件上传功能

在java项目中使用Demo如何实现一个文件上传功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。说到文件上传我们要做到:1.引入两个包:commons-fileupload-
2023-05-31

如何在PHP项目中利用Laravel实现一个文件下载功能

如何在PHP项目中利用Laravel实现一个文件下载功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。download 方法可以用于生成强制让用户的浏览器下载指
2023-05-31

编程热搜

目录