阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

Supersonic 框架宣称 iOS 和 Android 混合应用也能有原生性能

  • 2014-12-26
  • 本文字数:2536 字

    阅读完需:约 8 分钟

AppGyver 日前宣布了一个全新的用于开发Android 和iOS 混合(Hybrid)移动应用的Supersonic 框架,并且承诺提供“真正的原生性能”,AppGyver 说,这得益于一个全新设计的实现混合应用的方式。Supersonic 也和其自家的跨平台混合应用IDE Steroids 做了集成。

Supersonic 以 CSS 框架 Ionic Cordova 为基础,但是它采用了另类的方式来混合使用 HTML5 代码和原生代码,被称之为多页面应用架构。这将给 UI 性能和处理页面复杂度带来好处,AppGyver 说,因而比其他竞争方案有明显的性能优势。

Supersonic 用它自己的方式来使用原生 UI 元素或 HTML/CSS 元素,因此像页面切换、模态对话框、导航栏、Tab 栏、绘图以及其它一些 UI 元素是完全原生的,这保证了整体的原生性能和用户体验。

为了了解更多关于 Supersonic 的信息,InfoQ 采访了 AppGyver 的开发总监 Harri Sarsa。

InfoQ:您能够介绍 Supersonic 内部架构的更多细节吗?

Harri:在原生层面上,我们有 AppGyver Wrapper,它是我们自己的 Objective-C 或者 Java 原生运行时,负责为 HTML5 内容提供真正的原生功能支持。它包含了一个微调过的 Cordova 但完全兼容 Cordova 插件。它还包含了一个宿主(Host)程序,通过 API 提供原生 UI 调用和导航功能,这是其他 Wrapper 所没有的;另外它还能让你通过本地服务器的方式去拿资源文件而不是通过文件系统去拿。

在 Wrapper 之上,我们有 Supersonic 框架,它包含了我们修改过的 Ionic,提供了很好的 CSS 框架,更重要的是,它还包含 JavaScript API 和项目结构能够让你访问原生级别的增强功能。不仅所有的 Cordova 核心 API 可供使用,而且还包括 Supersonic 专有的 API 去访问原生 UI 组件。比如说,我们没有使用绝对定位“position: absolute”的一个 div 结点作为顶部导航栏,而是使用原生的导航栏,这意味着它总能够保证在正确的位置。我们使用 HTML5 的 Web Components 来启用原生元素,例如,原生导航栏就是使用一个 Web Component 来实现的。

除此之外,Supersonic 还是独立于前端框架的,你可以使用你喜欢的任何框架。不过我们非常喜欢 AngularJS,因此有很多例子都是用 Angular 实现的。

在这些 UI 之上是 Supersonic 数据层,能够实现“三向数据绑定(three-way data binding)”,让你的 View 始终和数据保持同步,包括在 Controller 中和后台服务中。Supersonic 数据层支持任何 REST 后端,你也可以通过我们免费提供的开发时数据库快速开始。

InfoQ:Supersonic 的多页面架构的优势是什么?

Harri:移动应用的构建和现在的 Web 应用有根本的不同。对大多数移动应用来说,在同一时间通常只有一个 View 出现在屏幕上,而不是像一个单页面 Web 程序(比如 Gmail)中一样包含复杂的,不断变化的 UI。你可以在多个 View 之间进行导航,比如从列表页面到详细内容页面。在一个完全的原生应用中,你创建应用的“Storyboard(故事板)”,原生的导航框架会负责这些 View 的切换,导航历史管理,共享 View 之间的数据,维护不可见的 View 的状态等等。

因为所有其它的混合应用框架受限于仅仅呈现唯一的 WebView,所以类似 Ionic 的框架只能使用单页面程序的方式:你只有一个 app.html 文件,然后 AngularJS 或其它的方案负责操作 DOM 来实现页面切换,展现新内容,维护导航历史等等。

在 Supersonic 中,我们把 App 分割成多个 HTML 页面,因而可以利用上高性能的原生导航。因此,当你从列表 View 切换到详细信息 View,没有任何 DOM 发生变化。取而代之的是,比如说你有一个汽车列表的 HTML 页面 cars/index.html,当点击列表中的某一辆车,列表页面的 JavaScript Controller 调用 API 将另外一个负责汽车具体信息的显示页面 cars/show.html 推入原生的导航栈,同时自然的提供了流畅的原生动画切换效果。这意味着最初的 index.html 存在于 show.html 之下,这很好的维护了导航状态。而且原生的返回按钮能够让你正确的返回。

同样的例子还包括抽屉式 / 侧栏菜单、Tab 导航等等,对它们的操作都无需发生任何 DOM 重绘。比如 Tab 页面切换能够瞬间完成,它完全由手机的 GPU 和 UI 引擎实现而不是由 WebKit 实现。

InfoQ:您能够简要的介绍下 Supersonic 的工具吗?

Harri:Supersonic 工具叫做 Steroids。基本上,你有一个基于 Node.js 的 CLI(命令行界面)可以创建新的 Supersonic 项目,生成代码结构,调试 Web 代码,启动 iOS 或 Android 模拟器,通过 Bower 和 npm 来管理依赖,查看设备上的日志等等。这个 CLI 同时支持 OS X,Windows 和 Linux。

整个开发的核心是一个名为 Scanner 的 App,你可以从 App Store 或者 Google Play 去下载。它能够和 Steroids 开发服务器一起工作,开发服务器也是通过 CLI 来启动。你通过扫描二维码来连接 Scanner 和你的电脑。然后 Scanner 从你的电脑下载 HTML5 内容和配置,并在你的设备上运行。这就让你的开发过程无需启动 XCode 或者 Android Studio(这也意味着你可以在 Windows 上进行 iOS 开发)。Scanner 应用包含了所有 AppGyver Wrapper 的原生代码,从而你的应用看上去完全是一个独立的编译过的 App。

本地开发结束后,你可以将应用部署在云上,从而够访问我们的 Build 服务。Build 服务可以 build 一个独立的二进制程序,让你能够将其提交到应用市场。

InfoQ:Supersonic 的发展方向是什么?

Harri:我们即将做的一些事情包括 Xcode 和 Android Studio 本地 Build,这可以加快插件开发;Supersonic 数据层的更多功能,比如即插即用的登录界面,一些 Steroids 和其他框架一起使用的例子,这些框架可以提供比如推送通知等新功能。

长远来看,我们希望 Supersonic 成为最好的混合应用开发框架,拥有能和原生 App 媲美的跨平台 App,同时还拥有深度而强大的数据集成。我们相信这种组合原生 +HTML5 的方式是正确的方向。

要了解更多 Supersonic 的信息,可以参考 AppGyver 提供的在线文档,以及一系列关于用户界面数据绑定工具使用的视频。

查看英文原文: http://www.infoq.com/news/2014/12/supersonic-hybrid-apps-dev


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2014-12-26 21:213828

评论

发布
暂无评论
发现更多内容

让 API 管理效率更进一步的 API7 DevPortal

API7.ai 技术团队

api 网关 API7

《2022年IT行业项目管理调查报告》重磅发布!

禅道项目管理

微帧自研|客观评价模型与主观DMOS分数拟合的分享与实用性探讨

微帧Visionular

计算机视觉 视频编解码

无需二次开发,SOAP-to-REST 简化企业用户的业务迁移和整合

API7.ai 技术团队

两会代表热议采用ChatGPT指导论文写作:防范抄袭的探索与思考

蓝海大脑GPU

人工智能 深度学习 ChatGPT

屡试不爽!一份阿里Java程序性能实战笔记,啃完让你程序快上200%

Java你猿哥

Java ssm 面经

软件测试/测试开发丨Docker 镜像构建可以分享的快乐

测试人

Docker 软件测试 测试开发

2 万字长文:声明式配置技术概述

Peefy

DevOps 编程语言 开发者工具 #Kubernetes# #开源

干货 | BitSail Connector开发详解系列一:Source

字节跳动数据平台

开源 数据集成 数据引擎 企业号 3 月 PK 榜

为什么 APISIX Ingress 是比 Emissary-ingress 更好的选择?

API7.ai 技术团队

全球运营商的新共识:2025走向自智网络L4

脑极体

自智网络

Capital

Echo_Wish

学习 进步 笔记 资源 本质

如何让人形机器人“行稳致远”?这篇顶级期刊的论文提出了新方法

优必选科技

机器人

复旦邱锡鹏:深度剖析 ChatGPT 类大语言模型的关键技术

NLP资深玩家

人工智能 ChatGPT

专业HTML文本编辑器:BBEdit 激活版

真大的脸盆

Mac Mac 软件 文本编辑器 文本编辑

最佳实践|焱融全闪存储实现与美的集团破千万 IOPS 性能

焱融科技

文件存储 分布式文件存储 高性能存储 全闪存储 美的

字节跳动DataLeap数据血缘实践

Openlab_cosmoplat

数据 开源社区 数据血缘

TCP 三次握手,给我长脸了噢

程序员小富

TCP

百度版ChatGPT:文心一言发布会盛大召开!

雪奈椰子

GPT-4炸圈--多模态大模型

江湖修行

人工智能 大模型 GPT ChatGPT GPT-4

最强阿里及大厂350道面试大全:框架+数据库+并发+开源+微服务

Java你猿哥

Java 数据库 架构 微服务 面经

李彦宏文心一言发布会 highlight

B Impact

【Docker】MacOs安装

Aldeo

Docker 云原生

使用价值三角方法来全方位分析产品

产品海豚湾

产品 产品经理 产品设计 产品运营 商业洞察

设计模式-策略模式

黑客不够黑

设计模式 策略模式

DevData Talks 直播预告 | 微众银行的研发效能实践有哪些经验?

思码逸研发效能

研发效能 DevData Talks

在追求卓越的路上,面对压力时,推荐你这二个做法。

叶小鍵

易观:正视GPT-4功能缺陷与能力局限可更好探索大模型应用

易观分析

科技

关于文件传输协议,你不知道的事

镭速

软件测试/测试开发丨学习Docker就应该掌握的dockerfile语法与指令

测试人

Docker 软件测试 测试开发

openGemini正式加入openEuler DB SIG,携手开展全方面技术创新

华为云开源

时序数据库

Supersonic框架宣称iOS和Android混合应用也能有原生性能_Android/iOS_Sergio De Simone_InfoQ精选文章