在当前的开发行业中,跨平台开发备受关注,同时也存在不少难题。许多开发者都希望能找到一种方法,使代码能在多个平台上高效运行。Hippy正致力于这一目标,力求让开发者摆脱因平台适配而带来的烦恼。
一Hippy的产生背景
移动互联网的兴起使得iOS、Web等平台对应用开发的需求显著增长。然而,不同平台拥有各自的规则和编程语言,这导致开发过程中人力投入较大。以过去的双端开发为例,其人力成本相当高昂。腾讯浏览器部门针对这一现象,推出了Hippy跨端框架,旨在让前端开发者仅需编写一套代码,便能在iOS和Web等主要平台上运行,从而显著提升开发效率。从开发团队的角度来看,这一举措能有效节约资源,是一次极具价值的探索。
这种跨平台的设计并非无中生有。市场上对高效开发方法的需求十分迫切,若开发人员需为每个平台单独编写代码,工作量将非常庞大。若能拥有一个跨端框架,开发团队就能将更多精力集中于其他功能的开发。
二开发语言与主流框架支持
Hippy致力于方便前端开发者,紧密遵循W3C标准,严格依照网页开发的各项规范。它选用适合的开发语言,这样的选择顺应了前端的发展趋势。此外,Hippy的显著优势在于它能够同时兼容React和Vue这两种主流的前端框架。例如,如果一个团队习惯用React框架进行开发,那么他们可以轻松地过渡到使用Hippy。同样,对于习惯Vue框架的开发者,在Hippy框架中也能很好地运用他们以往的经验,有效降低了学习新框架的难度。
在开发实践中,众多企业的前端部门会依据项目特性挑选恰当的框架。Hippy这一框架兼容两种选择,从而让开发者无需在框架间犹豫,可以将注意力集中于实际开发任务,有效提升开发速度。
三高性能架构的实现
Hippy采用了独特的引擎直通设计。这种设计在React中也有类似应用。其优势在于,它是用C++编写的模块,可以直接嵌入JS引擎执行。例如,在腾讯的一些内部应用开发中,Hippy避开了前端终端通信编解码的消耗,从而显著提高了JS前端代码与终端之间的通信效率。这使得应用运行更加顺畅,降低了卡顿现象。
在需要高性能的场景下,比如某些大型网络游戏或是那些对渲染速度有极高要求的软件,这种架构能显著提高数据传输速率。据腾讯内部开发者进行的测试,这种架构对性能的提升作用明显。
四人力节省情况
依据Hippy的使用经验,与原有的iOS双端开发相比,Hippy可以减少70%的人力投入。以腾讯内部的一个开发项目为例,原先进行双端开发需要10名开发人员,耗时两个月。而采用Hippy后,大约只需3名开发人员,在相同时间内就能完成从界面布局到功能配置等所有开发工作。
这70%的人力减少意味着什么?这表明项目在人员成本上有了显著下降。公司可以利用这部分节省的人力资源,投入到其他项目或技术研发中。而对于开发者而言,则有机会整合资源,开发出更多的项目。
五组件相关情况
Hippy在腾讯内部构建了一个完善的生态系统。其中包括了诸如HTML、CSS、SVG等元素的组件封装。此外,腾讯还拥有自主研发的Hippy业务组件库、高效的图形库以及异常上报系统(支持相关功能)。这些资源将逐步向外界开放。比如,在开发社交应用时,开发者可以借助Hippy的社交组件库,快速搭建起应用的基础功能架构。
此外,hippy-react在语法上更贴近设备底层,这便于开发者更精准地操控终端操作。hippy-vue的组件、参数和接口完全契合浏览器规范,这使得前端工程师只需借助浏览器标签和常规CSS选择器,便能轻松绘制跨平台界面。换句话说,开发者已有的网页操作经验可直接应用于跨平台开发。
六开发和调试操作注意事项
启动Hippy应用时,可利用hippy-react或hippy-vue的示例项目来运行iOS模拟器。iOS开发者通常推荐使用模拟器进行开发与调试,不过熟练的iOS开发者可以调整设置,将Hippy应用部署至手机。但开发者的情况各异。由于Hippy依赖的X5JS引擎不支持x86架构,且ARM模拟器运行速度较慢,因此建议直接在真机上开发。在开始开发前,务必核实SDK和NDK已安装示例项目要求的版本,同时避免更新编译工具链。此外,应以特定方式打开终端中的示例工程,并在连接手机时确保手机开启了USB调试和USB安装功能。
各位读者,你们认为Hippy在跨端开发方面能带来怎样的变革?期待你们的评论交流。若文章对您有所帮助,请记得点赞并转发分享。
Hippy├── examples # 前终端范例代码。│ ├── hippy-react-demo # hippy-react 前端范例代码。│ ├── hippy-vue-demo # hippy-vue 前端范例代码。│ ├── ios-demo # iOS 终端范例代码。│ └── android-demo # Android 终端范例代码。├── packages # 前端 npm 包。│ ├── hippy-debug-server # Hippy 的前终端调试服务。│ ├── hippy-react # Hippy 的 React 语法绑定。│ ├── hippy-react-web # hippy-react 转 Web 的库。│ ├── hippy-vue # Hippy 的 Vue 语法绑定。│ ├── hippy-vue-css-loader # 用来将 CSS 文本转换为 JS 语法树以供解析的 Webpack loader。│ ├── hippy-vue-native-components # hippy-vue 中浏览器中所没有的,额外的,终端定制组件。│ └── hippy-vue-router # 在 hippy-vue 中运行的 vue-router。├── ios│ └── sdk # iOS SDK。├── android│ ├── support_ui # Android 终端实现的组件。│ └── sdk # Android SDK。├── core # C++ 实现的 JS 模块,通过 Binding 方式运行在 JS 引擎中。├── layout # Hippy 布局引擎。├── scripts # 项目编译脚本。└── types # 全局 Typescript 类型定义。