您当前的位置:首页 > 电脑百科 > 程序开发 > 框架

移动端开发框架选择及实践

时间:2022-06-07 10:30:33  来源:  作者:晖晖yyds
移动端开发框架选择及实践

 

一、移动端框架选型

1、原生or 混合 or web

选型问题其实我并没有考虑,因为根据我们实际情况,最适合的还是混合开发。这里大概阐述一下原生、混合、web的区别。

原生开发没什么可说的,体验肯定是最好的,但是需AndroidIOS两批人,小程序还要加人,人力成本相对较高。

这里所说的web是指用webview包装,主要问题是体验不太好,开发成本最低。

而混合开发则结合两者的优势,即可感受原生的体验,也可享受热更新。原生通过js调用android及ios的API(iOS是jscore,Android是v8)。特别是首页,列表等页面达到近似于原生的性能,也可以通过webview达到热更新的便利。

这里选型主要考虑人力情况、开发成本情况、人才的知识结构等。见下图:

2、三大框架

不讨论。根据人员知识结构决定了选择vue。

3、flutter or uniApp

这里特别说下flutter,因为它是google的产品,性能高。但它也只是个界面库。渲染性能排序:flutter>js调用原生渲染(react native/weex/uni-app)>webview渲染。但是flutter的写法很有可奇葩,不适应web开发者;另外三方接口调用方面能力弱。虽然flutter的发展势头不错,但对我们团队来说,成本还是太高。

二、uniapp框架选择

其实在写文章之前已经决定采用uniapp了,并不是它有多好,而是它适合我们目前的小团队。由于之前我们已经用uniapp来开发app,但由于库太旧,对nvue的支持弱,就决定升级原框架及页面,但并不想从头开始构造,于是选择合适的基础通用框架。

1、uni-starter

dcloud官方提供的快速框架,官方描述:uni-starter是一个集成了大量商用项目常见功能的,云端一体应用快速开发基本项目模版。APP有很多通用的功能,比如登录注册、头像、设置、banner、... uni-starter将这些功能都已经集成好。

其实已经基本满足一个通用框架的基本条件,本来准备采用它,但是它后台基于uniCloud,而且“不能将后台改成phpJAVA等其他后台,这将违反使用许可协议“,由于我们后台有自己的框架,所以只能放弃了。

2、uni-xiaofan

最终我们采用的基础框架。

原因有三:

(1) 跟旧框架一脉相承,升级成本低。

(2) 采用uview2,支持nvue。

(3) Mit协议,且目前作者在维护。

3、ruoyi-uniapp

基于ruoyi的基础框架,目前只实现部分功能,界面可借鉴。

最终我们采用uni-xiaofan框架,并借鉴uni-starter及ruoyi-uniapp的部分功能。

三、uniapp实践

1、实践目标

(1)平台必须支持app(android和Ios),微信小程序、Chrome。

(2)app尽量采用nvue,特别是首页和列表部分。

(3)尽量采用flex布局,布局不使用百分比、没有媒体查询。

(4)基本框架支持vue3,尽量同时支持vue3。

(5)部分功能用uni-cloud实践,如版本升级及问题反馈功能。

2、UI库

本项目UI库主要采用uni-app自带的,再结合第三方库。第三方基础库主要采用uview2.0。

优先级:内置组件>uni-ui扩展组件>uview2.0组件>…

可通过uni_modules来安装扩展组件,不需要引用、注册,并可以通过右键快速更新组件。

3、布局

支持跨平台,框架使用 Flex 布局。

4、css

※尽量不使用百分比布局,如width:100%

※class 进行绑定时只支持数组语法。

※不支持媒体查询。

※不能在 style 中引入字体文件。

※不支持在css里写背景图background-image,但可以使用image组件和层级来实现类似web中的背景效果。因为原生开发本身也没有web这种背景图概念。

※设置background-color。

※文字内容,必须只能在text组件下,text组件不能换行写内容,否则会出现无法去除的周边空白。

※只有text标签可以设置字体大小,字体颜色。

另外尽量不使用uview2.0中的内置样式。

5、国际化

目前框架已支持国际化。使用时{{$t('mine.notLoggedInfo')}}or$t('mine.feedback')调用即可。

6、支持uniCloud

虽然我们不完全采用uniCloud,但是部分功能可通过unicloud实现,如版本升级及问题反馈等,实现更便捷。

四、uniapp页面

1、我的

 

移动端开发框架选择及实践

 

2、消息

 

移动端开发框架选择及实践

 

3、通讯录

 

移动端开发框架选择及实践

 

4、工作台

 

移动端开发框架选择及实践

 



Tags:开发框架   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
五大跨平台桌面应用开发框架:Electron、Tauri、Flutter等
一、什么是跨平台桌面应用开发框架跨平台桌面应用开发框架是一种工具或框架,它允许开发者使用一种统一的代码库或语言来创建能够在多个操作系统上运行的桌面应用程序。传统上...【详细内容】
2024-02-26  Search: 开发框架  点击:(52)  评论:(0)  加入收藏
10大Web开发框架有哪些?
Web开发框架是企业实现独特Web应用程序的有力工具,因为它们在为开发人员提供工具和库方面发挥着至关重要的作用。开发人员发现使用框架提供的库和模板来制作交互式和用户友好...【详细内容】
2023-11-20  Search: 开发框架  点击:(201)  评论:(0)  加入收藏
谷歌的Project IDX会扼杀其他应用程序开发框架吗?
作者丨Mohit Pandey编译丨千山桌面应用、App、小程序、物联网终端设备......面对业务日益复杂的终端适配需要,跨平台应用开发框架的使用趋势只增不减。它允许开发人员使用一...【详细内容】
2023-08-17  Search: 开发框架  点击:(263)  评论:(0)  加入收藏
H5开发框架
跨平台移动应用开发框架允许开发者使用一套代码在多个操作系统上构建应用程序,从而节省时间和资源。以下是一些常见的跨平台移动应用开发框架以及它们的特点,希望对大家有所帮...【详细内容】
2023-08-11  Search: 开发框架  点击:(257)  评论:(0)  加入收藏
开发框架Spring核心技术含Resource接口详细讲解
前言Spring 是 Java EE 编程领域的一款轻量级的开源框架,由被称为“Spring 之父”的 Rod Johnson 于 2002 年提出并创立,它的目标就是要简化 Java 企业级应用程序的开发难度...【详细内容】
2023-06-21  Search: 开发框架  点击:(375)  评论:(0)  加入收藏
微信小程序六大开发框架如何选
随着微信、支付宝等开放平台的壮大,移动应用生态市场的蓬勃发展,例如小程序已经成为各个企业和开发者的重要选择。为了提高小程序的开发效率和代码重用性,许多第三方开发框架应...【详细内容】
2023-05-17  Search: 开发框架  点击:(252)  评论:(0)  加入收藏
基于JWT的RuoYi开发框架与EMQX的系统集成方法
我们使用JwtAccessTokenConverter来生成Jwt Token,JwtAccessTokenConverter默认使用的Signer是MacSigner,而MacSigner默认的算法是HMACSHA256。下面这个地方配置的Signkey一...【详细内容】
2023-05-17  Search: 开发框架  点击:(96)  评论:(0)  加入收藏
一套移动端高性能高可用的动态化跨端开发框架
《开源精选》是我们分享Github、Gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的是一个跨端开发框架,支持 Android 和 iOS 应用—&m...【详细内容】
2023-02-06  Search: 开发框架  点击:(290)  评论:(0)  加入收藏
浅谈跨平台应用程序开发框架
随着移动互联网的快速发展,微信小程序、Web、App、 车载等各种形态的“端”悄然盛行。而同一个业务需求往往又需要在多端上去实现,针对不同端去编写多套代码的成本显然非常高...【详细内容】
2023-01-09  Search: 开发框架  点击:(297)  评论:(0)  加入收藏
码云最有价值的桌面软件开发框架!
《开源精选》是我们分享Github、gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的是一个入门简单、跨平台、企业级桌面软件开发框架。 ...【详细内容】
2023-01-09  Search: 开发框架  点击:(292)  评论:(0)  加入收藏
▌简易百科推荐
Qt与Flutter:在跨平台UI框架中哪个更受欢迎?
在跨平台UI框架领域,Qt和Flutter是两个备受瞩目的选择。它们各自具有独特的优势,也各自有着广泛的应用场景。本文将对Qt和Flutter进行详细的比较,以探讨在跨平台UI框架中哪个更...【详细内容】
2024-04-12  刘长伟    Tags:UI框架   点击:(7)  评论:(0)  加入收藏
Web Components实践:如何搭建一个框架无关的AI组件库
一、让人又爱又恨的Web ComponentsWeb Components是一种用于构建可重用的Web元素的技术。它允许开发者创建自定义的HTML元素,这些元素可以在不同的Web应用程序中重复使用,并且...【详细内容】
2024-04-03  京东云开发者    Tags:Web Components   点击:(11)  评论:(0)  加入收藏
Kubernetes 集群 CPU 使用率只有 13% :这下大家该知道如何省钱了
作者 | THE STACK译者 | 刘雅梦策划 | Tina根据 CAST AI 对 4000 个 Kubernetes 集群的分析,Kubernetes 集群通常只使用 13% 的 CPU 和平均 20% 的内存,这表明存在严重的过度...【详细内容】
2024-03-08  InfoQ    Tags:Kubernetes   点击:(23)  评论:(0)  加入收藏
Spring Security:保障应用安全的利器
SpringSecurity作为一个功能强大的安全框架,为Java应用程序提供了全面的安全保障,包括认证、授权、防护和集成等方面。本文将介绍SpringSecurity在这些方面的特性和优势,以及它...【详细内容】
2024-02-27  风舞凋零叶    Tags:Spring Security   点击:(62)  评论:(0)  加入收藏
五大跨平台桌面应用开发框架:Electron、Tauri、Flutter等
一、什么是跨平台桌面应用开发框架跨平台桌面应用开发框架是一种工具或框架,它允许开发者使用一种统一的代码库或语言来创建能够在多个操作系统上运行的桌面应用程序。传统上...【详细内容】
2024-02-26  贝格前端工场    Tags:框架   点击:(52)  评论:(0)  加入收藏
Spring Security权限控制框架使用指南
在常用的后台管理系统中,通常都会有访问权限控制的需求,用于限制不同人员对于接口的访问能力,如果用户不具备指定的权限,则不能访问某些接口。本文将用 waynboot-mall 项目举例...【详细内容】
2024-02-19  程序员wayn  微信公众号  Tags:Spring   点击:(43)  评论:(0)  加入收藏
开发者的Kubernetes懒人指南
你可以将本文作为开发者快速了解 Kubernetes 的指南。从基础知识到更高级的主题,如 Helm Chart,以及所有这些如何影响你作为开发者。译自Kubernetes for Lazy Developers。作...【详细内容】
2024-02-01  云云众生s  微信公众号  Tags:Kubernetes   点击:(58)  评论:(0)  加入收藏
链世界:一种简单而有效的人类行为Agent模型强化学习框架
强化学习是一种机器学习的方法,它通过让智能体(Agent)与环境交互,从而学习如何选择最优的行动来最大化累积的奖励。强化学习在许多领域都有广泛的应用,例如游戏、机器人、自动驾...【详细内容】
2024-01-30  大噬元兽  微信公众号  Tags:框架   点击:(72)  评论:(0)  加入收藏
Spring实现Kafka重试Topic,真的太香了
概述Kafka的强大功能之一是每个分区都有一个Consumer的偏移值。该偏移值是消费者将读取的下一条消息的值。可以自动或手动增加该值。如果我们由于错误而无法处理消息并想重...【详细内容】
2024-01-26  HELLO程序员  微信公众号  Tags:Spring   点击:(95)  评论:(0)  加入收藏
SpringBoot如何实现缓存预热?
缓存预热是指在 Spring Boot 项目启动时,预先将数据加载到缓存系统(如 Redis)中的一种机制。那么问题来了,在 Spring Boot 项目启动之后,在什么时候?在哪里可以将数据加载到缓存系...【详细内容】
2024-01-19   Java中文社群  微信公众号  Tags:SpringBoot   点击:(91)  评论:(0)  加入收藏
站内最新
站内热门
站内头条