行业资讯

广州小程序开发,广州app开发等最新行业资讯

如何开发一款优秀的App

时间:2024-11-29 07:55:54 | 作者:广州红匣子科技 | 阅读量:25084

如何打造优秀的跨平台APP及跨平台APP开发经验总结|社区随笔.

一.前言

对于经常使用APP且技术性敏感的用户,在操作APP过程中,对于一个页面是native App还是hybird App实现,往往一眼就能识别出来谁是网页质感,谁是原生质感,

在实际想法开发过程中,项目组在制定产品研发策略时,考虑到开发成本(时间、金钱)和上手难度,Hybrid App成为技术框架首选。因为Hybrid App只需要编写一套代码,便可以同步生成AndroidIOS两个平台的APP,甚至能够部分兼容微信公众号和小程序。这样节省的不仅仅是写代码的时间,更重要的是节省了多个技术团队之间跨知识结构协同的问题,同时也节省了APP与服务器端调试的时间成本。

一般,我们对Hybrid App的定义是:

Hybrid App(混合模式移动应用)是指介于web-appnative-app这两者之间的app,兼具“Native App良好用户交互体验的优势”和“Web App跨平台开发的优势”。

简单来说,Hybrid App就是套壳 App,整个 App 还是原生的,也需要下载安装到手机,但是 App 里面打开的页面既可以是 Web 的,又可以是原生的。H5 页面会跑在 Native 的一个叫做WebView的容器里面,只要有 WebView,一套代码可以很容易跨iOS、安卓、Web、小程序、快应用多个平台。可以简单理解为在 App 里面打开了一个 Chrome 浏览器,在这个浏览器里面打开一个 Tab 去加载线上或者本地的 H5 页面,这样还可以实现打开多WebView来加载多个页面。

受制于 Web 性能,Hybrid App具有加载速度比较慢、页面渲染问题,包括页面渲染性能差、页面卡顿、白屏等问题层出不穷。

如何打造一款优秀的Hybrid App,使其体验上更像客户端,运行更高效是一个值得探索的课题。

二、Hybrid App 技术选型

Native app开发技术一般比较固定,大厂背景下,很难出现百家争鸣百花齐花的现象。原生开发技术实现如下:

IOS:基于XCode开发工具,使用Swift或者OC开发语言,来进行原生态的IOS应用的开发。

Android:基于Eclipse或者Android Studio开发工具,使用Java或者Kotlin开发语言,来进行原生态的Android应用的开发。

Hybrid App采用H5技术实现,技术选型就比较广泛了。目前主流的移动端跨平台技术方案大体可以分为三类,

使用原生内置浏览器加载HTML5的Hybrid技术方案,采用此种方案的主要有CordovaIonic和微信小程序;使用JavaScript语言进行开发,然后使用原生组件进行渲染,采用此方案的主要有React NativeWeex和轻快应用;使用自带的渲染引擎和自带的原生组件来实现跨平台,采用此种方案的主要是Flutter

对于其他的跨平台开发方案,基本可以抛弃了,相比较React NativeFlutterReact NativeFlutter在应用开发上,效率差不多。

Tips⚠️:

React Native: 由Facebook于2015年发布的开源、跨平台的应用开发框架。其基于React.JS实现,利用JavaScriptAndroidiOS用户提供真正原生的应用外观和体验。另外,该框架还支持开发者使用JavaObjective-CSWIFT编写部分原生模块来处理复杂操作,如视频播放或图像编辑。

Flutter: 由Google于2018年开源的构建用户界面(UI)工具包,其基于Dart编译器和Flutter拥有基于DART编写的“UI-as-a-code”小部件,它的性能比任何其他跨平台移动开发框架都要好,能更快、更直接地与平台直接通信,而不需要JavaScript桥(Reaction Native就是通过JavaScript桥进行通信)。此外,Flutter不依赖于某一组原生组件,而是利用可视化、结构化、平台性和交互式小部件进行UI设计,所有这些实现都由框架图形引擎负责完成。

除此之外,国产跨平台开发框架uni-app近几年也逐渐在支持国产的潮流中异军突起,uni-app支持webview渲染weex原生渲染这2种引擎渲染方式。

webview渲染方式:架构和微信小程序一样。

原生渲染方式:DCloud 基于 weex引擎进行了改造,在原生渲染引擎上实现了uni-app的组件和API。

uni-app作为国产跨平台开发框架,只能说是站在巨人的肩膀上成就了自己,要说其没有创新性也不完全正确,说其是剽窃,也谈不上。鲁迅先生曾经说过:“读书人偷书不算偷” 。

三、uni-app 如何打造优秀的跨平台APP

考虑到目前项目组应用uni-app作为跨平台开发框架,故本节讨论应用uni-app如何打造一款优秀的跨平台APP。

下面主要从页面渲染,问题排查等方面介绍APP开发、纠错经验。

3.1 页面渲染

如何让uni-app 开发的hybrid App看起来更像原生APP?这是在开发Hybrid App时不得不面对的一个犀利问题。

首先,要清楚H5页面在APP端渲染的方式,相比原生少了很多页面渲染效果。

提升H5加载速度APP运行过程中,字体文件过大导致APP端通过webview方式引用H5内容会出现加载慢的用户体验问题。

针对此问题,需要对字体文件进行筛选、压缩处理,同时开启服务器端gzip压缩。

使用自定义组件模式使用自定义组件模式,在manifest.json配置文件中配置自定义组件模式(HBuilderX1.9起新建项目默认即为自定义组件模式)。

在复杂页面中,页面中嵌套大量组件,如果是非自定义组件模式,更新一个组件会导致整个页面数据更新。而自定义组件模式则可以单独更新一个组件的数据。

在App端,除了上述好处,自定义组件模式还新增了一个独立的js引擎,加快启动速度、减少js阻塞。

避免使用大图页面中若大量使用大图资源,会造成页面切换卡顿,导致系统内存升高,甚至白屏崩溃。

尤其是不要把多张大图缩小后显示在一个屏幕内,比如上传图片前选了数张几M照片,然后缩小在一个屏幕中展示多张几M的大图,非常容易白屏崩溃。

图片样式处理当页面结构复杂,css样式太多的情况,使用<image>可能导致样式生效较慢,出现 “闪一下” 的情况,此时全局设置image{will-change: transform}可优化APP页面闪烁问题。

图片懒加载骨架屏和懒加载的实现效果类似。骨架屏和懒加载的区别是什么?骨架屏是连图带文字全都要做骨架,懒加载只是图片做即可,效果类似,都是灰色的底色。关于懒加载方案,uniapp的<image>lazy-load属性支持APP(不支持H5),所以APP可以用。

优化数据更新在 uni-app 中,定义在 data 里面的数据每次变化时都会通知视图层重新渲染页面。 所以如果不是视图所需要的变量,可以不定义在 data 中,可在外部定义变量或直接挂载在vue实例上,以避免造成资源浪费。

减少一次性渲染的节点数量页面初始化时,逻辑层如果一次性向视图层传递很大的数据,使视图层一次性渲染大量节点,可能造成通讯变慢、页面切换卡顿,所以建议以局部更新页面的方式渲染页面。

如:服务端返回100条数据,可进行分批加载,一次加载50条,500ms 后进行下一次加载。

减少节点嵌套层级深层嵌套的节点在页面初始化构建时往往需要更多的内存占用,并且在遍历节点时也会更慢些,所以建议减少深层的节点嵌套。

骨骼屏应用由于APP的容器是默认撑起高度的,而H5页面容器可能在打开的瞬间是无高度的,因为没内容,等请求到内容后才忽然撑起高度。就会导致界面闪、晃动等用户体验问题。

可以考虑应用骨架屏做到提前撑起容器高度。

接口设计减小接口响应报文体,响应体内容过多会导致页面渲染数据量过大,导致页面渲染慢。可以考虑将接口设计为图片、文字接口,可以优先渲染页面文字,然后再渲染页面图片。

3.2 问题排查

APP问题排查方面,目前可借助的调试工具并不多,尤其对于页面白屏、APP闪退的分析工具更是很少。

3.2.1 vConsole

vConsole是由腾讯出品的 Web 调试面板,相信不少前端工程师都使用过。vConsole会在网页中加一个悬浮的小按钮,可以点击它来打开关闭调试面板,并查看DOMConsoleNetwork和 本地存储 等信息。基本可以满足普通前端开发的使用需求。

vConsole使用方法也很简单,通过npm安装或者直接在需要的页面引入 js文件 ,然后new VConsole()就可以了。不熟悉的童鞋可以直接去官方的 GitHub 查看 README。但是当系统 bug 严重到一定程度,例如一进页面就报错,脆弱的javascript直接原地爆炸,页面一片空白,此时vConsole就会显得苍白无力了。

vConsole类似的另一款调试工具是eruda。

3.2.2 weinre

weinre 是一款很不错的网页检查工具,可以通过在本地启动一个weinre服务,并向手机网页嵌入一段 js 脚本来实现和电脑的通信,已达到类似浏览器开发工具那样的的调试效果,它的操作界面和vConsole差不多,主要包括查看DOMConsoleNetwork等,只不过这一切是在电脑上操作,而不是在手机上。

3.2.3 Charles

Charles 是一款强大的应用层抓包工具,可以截取包括https在内的各种网络请求并方便的查看具体信息。有 Mac、Windows 和 Linux多版本,通过配置 WIFI 代理,可以拦截手机发出的请求。毕竟前端相当一部分报错是网络错误或数据不符合预期导致的。所以通过拦截 http(s) 请求,查看具体的请求信息和数据,能获取很多有用的信息,可以在一定程度上帮助 debug。但是该软件是付费软件,而且它定位不了 js 报错,所以也是只能作为一个辅助工具。

Charles类似的另一款应用层抓包工具是 Fiddler。

3.2.4 Wireshark

CharlesFiddler可以帮助捕获和分析 HTTP 层面(即应用层)的问题,如果问题发生在TCP/IP(即网络层)层面,则需要 TCP 报文的捕获和分析工具。

Wireshark(支持 Mac/Windows 平台)、Network Monitor(Windows 平台)和TCPDUMP是常用的三种网络层抓包工具。比较常见的网络层问题包括SSL 握手失败TCP 链接中断、重发等。

大部分hybrid app 开发工程师是由web 开发工程师转过来的,在项目中引用三方插件时可能会要求原生方式引入,因此引入质量就很难保证。而且在项目调优过程中就会存在由于不清楚原生底层工作机制导致调优效果甚微。因此,建议从事hybrid app开发的童鞋还是需要补充原生app开发技能。

四、拓展阅读

《Angular.js官网》《Vue.js官网》《React官网》《React Native官网》《React Native GitHub》《uni-app官网》《Flutter中文网》《Flutter GitHub》《Android官网》《IOS官网》《vConsole GitHub》《Charles 官网》《Fiddler 官网》《Wireshark 官网》



如何开发一款优秀的App?

一、明确需求分析

首先,要开发一款优秀的App,必须从用户的角度出发,深入了解用户的需求。这可以通过市场调研、用户访谈、问卷调查等方式进行。收集到的用户需求数据需要进行整理和分析,以便为后续的App设计和开发提供有力的依据。明确的需求分析有助于确保App的功能和特性能够满足用户的期望,从而提升用户体验。

二、优秀的设计

设计是App开发的关键环节,它包括界面设计、交互设计、用户体验设计等。一个优秀的App设计应该具备简洁、直观、美观和易于操作的特点。在设计过程中,要充分考虑用户的需求和习惯,确保用户能够轻松上手并愉快地使用App。此外,设计还需要与App的功能和特性相契合,以提升整体的用户体验。

三、高质量的开发

开发是实现App功能的关键步骤。在开发过程中,需要遵循一定的开发规范和标准,确保代码的质量和可维护性。同时,开发团队需要具备良好的沟通和协作能力,以便在开发过程中及时解决问题和调整方向。此外,开发过程中还需要注重性能优化和安全性保障,确保App在运行过程中能够快速响应、稳定运行并保护用户隐私和数据安全。

四、严谨的测试

动词 (verb的缩写)有效推广



这为特殊段:作者编辑、收集相当艰难,不图回报,有不明白地方请指教16620511776(可微可电)互动。

一个app如何开发才能迎合用户体验?

首先,研究用户偏好

开发一款适合用户的APP,首先要进行用户喜好研究,比如:分析用户使用APP的偏好,了解用户的社会属性、消费行为、消费偏好、消费背景以及用户的地理位置等。这些信息可以帮助开发者了解用户的需求,为APP的设计与开发提供参考。

二、设计友好的界面

设计一款受用户喜爱的APP,界面设计也是一个必不可少的环节。界面设计要有良好的可读性,色彩要淡雅,字体要清晰,图标要清晰,操作方式要简单易懂,用户体验要好,界面设计要精美简洁,让用户看到一个漂亮的界面,觉得APP很有品位。

三、支持多种设备

用户都有不同的使用习惯,所以APP的开发要考虑到不同设备的支持,要支持iOS、Android、Windows这三大平台,并且要兼容多种分辨率,比如:要支持1024×768、1280×800、1920×1080等多种分辨率,同时APP也要兼容多种浏览器,如IE10、Chrome、Firefox等。

四、提供安全可靠的服务

安全是APP开发的重要环节,APP要对用户信息和数据提供安全可靠的服务,要有完善的数据安全策略,保证用户的隐私安全,同时APP要提供安全可靠的服务,让用户在使用APP的同时,能够安心的使用,不用担心数据丢失或受到恶意破坏。

五、提供便捷的服务

APP要提供便捷的服务,比如:提供用户一键登录服务,一键购买服务,一键支付服务,一键订餐服务等,让用户在使用APP时更加便捷,节省时间,提高效率。

六、提升用户体验

APP要不断提升用户体验,比如:定期更新APP,改进用户界面,提升APP性能,优化用户体验,添加新的功能,增加更多的服务,以及提供更多的折扣优惠等,让用户在使用APP时更加愉悦。

开始制作

用户 过程中 测试 如何开发一款优秀的App

上一篇:中医APP的开发费用会受到多种因素的影响

下一篇:开发一款旅游类的app需要多少费用?

推荐阅读

联系我们

电话:16620511776(邓经理)

邮箱:junfeng@hboxs.com

广州总公司地址:广州市天河区-丰兴广场B栋23楼

北京分公司地址:朝阳区建国路108号横琴人寿大厦9层

上海分公司地址:松江区伴亭东路288号2号楼6楼

杭州分公司地址:拱墅区兴业街29号金通数字科创园8号楼

武汉分公司地址:汉阳区-升官渡经贸大厦

深圳分公司地址:罗湖区松园社区笋岗东路3013号长虹大厦

南京分公司地址:南京智芯路4号红枫科技园B3栋

山东分公司地址:临沂市兰山区开元上城国际B座

湖北分公司地址:孝感市董永路宇济滨湖天地梅苑

吉林分公司地址:长春市朝阳区开运街富腾家天下1幢A1单元

苏州分公司地址:苏州片区苏州工业园区星湖街328号

福建分公司地址:福州市台江区德榜路12号

郑州分公司地址:金水东路80号绿地新都会6号楼

成都分公司地址:金牛区花照壁西顺街318号1栋2单元30层

微信扫码联系

Copy Right © 广州红匣子信息技术有限公司 2014-2025 保留一切权利 jdv2.com All rights reserved

企业备案号:粤ICP备14083821号-4 | 高新技术企业编号: GR201744004496 | xml网站地图 网站地图

商务售前咨询

16620511776
邓经理

联系我们
电话联系 微信联系 项目案例