移动端开发框架选择及实践 移动开发ui框架
liuian 2024-12-22 19:35 51 浏览
一、移动端框架选型
1、原生or 混合 or web
选型问题其实我并没有考虑,因为根据我们实际情况,最适合的还是混合开发。这里大概阐述一下原生、混合、web的区别。
原生开发没什么可说的,体验肯定是最好的,但是需android、ios两批人,小程序还要加人,人力成本相对较高。
这里所说的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,而且“不能将后台改成php、java等其他后台,这将违反使用许可协议“,由于我们后台有自己的框架,所以只能放弃了。
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、工作台
相关推荐
- 手机cpu排名2025(手机cpu排名榜)
-
一、2022手机CPU性能综合排名前八名手机CPU:1、型号:苹果A16---综合分数:暂无2、型号:骁龙8gen1---综合分数:42333、联发科天玑9000---综合分数:38724、...
- 论坛系统(论坛系统数据流图)
-
BBS是电子布告栏系统的简称,一种网站系统,也是目前流行网络论坛的前身。它允许用户使用终端程序通过调制解调器拨接或者因特网来进行连接,BBS站台提供布告栏、分类讨论区、新闻阅读、软件下载与上传、游戏、...
- hp1020plus打印机无法打印(惠普1020plus打印机突然不能打印了)
-
删除惠普打印机驱动和软件:1.如果你的打印机已通过USB连接到电脑,断开USB连接;2.打开控制面板—程序和功能(卸载或更改应用程序);3.在软件列表中找到惠普打印机,将其卸载;4.重启电脑...
- wifi密码破解器电脑版(wifi密码破解工具电脑版)
-
肯定不是万能钥匙这种“破解”wifi的东西。不是一两次见到把万能钥匙当做破解wifi用的人了,但实际上那玩意就是个分享wifi的软件。你连上一个wifi,密码就会被分享到云端(可以不分享),别...
- 手机临时文件夹在哪个位置(手机临时文件夹在哪个位置找)
-
1.手机文件临时文件是指在手机使用过程中产生的临时文件。2.手机应用程序在运行时需要产生一些临时文件,如缓存文件、日志文件、临时下载文件等,这些文件可以提高应用程序的运行效率和用户体验。但是,这些...
- 安卓10系统下载(安卓10 下载)
-
方法及步骤: 其实使用安卓车机下载歌曲的方法十分的简单,具体操作步骤和安卓手机一模一样。 首先我们需要在车机的应用商店上,下载一个音乐播放器,例如网易云音乐或者QQ音乐等。 下载完成后点击进入...
- 华硕人工客服24小时吗(华硕售后人工客服)
-
华硕服务中心广东省惠州市惠东县城平深路(创富斜对面)惠东同心电脑城1L11(1.3km)笔记本电脑,平板电脑华硕服务中心广东省惠州市惠东县平山镇同心电脑城1F26(1.3km)笔记本电脑,平...
- 电脑音量小喇叭不见了(电脑声音喇叭图标不见了怎么办)
-
如果您电脑上的小喇叭(扬声器)不见了,可以尝试以下方法找回:1.检查设备管理器:在Windows下,右键点击“我的电脑”(或此电脑)->点击“属性”->点击“设备管理器”,查看“声音、视...
- 腾达路由器手机设置教程(腾达路由器手机设置教程视频)
-
用手机设置腾达路由器的方法如下:1在手机上打开浏览器,输入路由器背面的管理IP和用户及对应的密码2一般第一次打开,默认会跳出设置向导,准备好宽带用户名和密码,3按向导提示输入相应内容4在无线设置的安全...
- 自配电脑配置推荐(自配电脑配置推荐百度)
-
首先,像这类软件最低要求不高。最高没上限。纯粹看你的工程量大小。CPU有双核,内存有4G,就可以运行。但是实际体验肯定比较差,卡是肯德。渲染时间也会超长,一个小作品渲染几小时是正常的。稍微大点的工程也...
- 2025年平板性价比排行(2020年值得买的平板)
-
推荐台电P30S好。 基本配置:10.1英寸IPS广视角屏幕,1280*800分辨率,16:10的黄金显示比例,K9高压独立功放,支持3.5mm耳麦接口,联发科MT8183八核处理器,4GB...
- 2020显卡天梯图10月(2020显卡天梯图极速空间)
-
排行球队名称积分已赛胜平负进球失球净胜球 1?诺维奇城974629107753639 2?沃特福德91462710...
-
- 笔记本电脑无线网络连接(笔记本电脑无线网络连接不上怎么办)
-
一、笔记本电脑怎么连接wifi---win7系统笔记本连接wifi1、要先创建无线网络连接,将鼠标移到Win7的开始菜单,然后点击“控制面板”。2、然后点击“网络和Internet”。3、再打开“网络和共享中心”,这是Win7系统必有的功...
-
2025-12-22 05:55 liuian
- wind数据库(wind数据库官网)
-
先购买wind数据库,安装好wind取得使用权后,按照wind所给提示,输入账户和密码可使用wind数据库。Wind资讯金融终端是一个集实时行情、资料查询、数据浏览、研究分析、新闻资讯为一体的金融数据...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
