最近我司的项目,需要在移动端上访问。本来是想采用 flutter 的新架构,但是考虑到学习成本和团队技术倾向(都具有 js 的背景,所以倾向于网页开发),于是收集了相关资料,打算使用 vue 开发适配于移动端的网页来使用。 现在有 1 个问题,就是领导们希望,访问的效果类似于真实的 app 。 例如:1.浏览器打开,网页是全屏的 2.不要用浏览器打开,最好像个 app 一样安装 我想请教下各位大哥们,有没有办法浏览打开的时候隐藏工具栏和地址栏,或者假设不行,那么开发 pwa 这样的方案是否合适 谢谢啊
1
murmur 2023-12-18 09:01:38 +08:00
必须得套壳,不过 cordova 已经几乎没有维护了,还不如 uniapp
|
2
Geo200 2023-12-18 09:04:30 +08:00
这说白了就是一个类原生体验场景的开发问题,跟 vue 没关系
|
3
hevi 2023-12-18 09:10:02 +08:00
不如考虑 react native 、uniapp 、taro ?
|
4
acthtml 2023-12-18 09:20:30 +08:00
用户非用不可,你又没资源开发的项目可以这样,否则流量转换都不行。
|
5
liujavamail 2023-12-18 09:20:34 +08:00 1
vue 的话,直接上 uniapp 就行, 不然就 ionic
|
6
zqlcrow 2023-12-18 09:21:36 +08:00
不想用 Flutter ,那肯定用 React Native 啊。
|
7
wuxidixi 2023-12-18 09:26:52 +08:00
效果不好的
|
8
kylebing 2023-12-18 09:36:03 +08:00 1
如果只是在网页层面实现各种功能,那么可以直接网页,我只知道 iOS 上可以通过 PWA 的方式实现类似 app 的展示效果。可以参考这个: https://kylebing.cn/diary/ 在 safari 中打开之后,分享,然后选择将 “添加到主屏幕”,再从主屏幕打开就跟 app 相似。
如果需要调用系统层面的功能,比如拍照、扫二维码、本地通知等,就需要一个壳子,这个壳子就相当于一个浏览器,不过这个壳子开放出了可以调用系统资源的一些接口供你在 web 层面调用。这些壳子有 ReactNative 、uniapp 、capacitor 等等,这些都可以打包成 iOS 和 Android 两个平台的安装程序。 前端时间写过一个 app ,就是用这些玩意写的,反正是很抓狂: - uniapp 到处是坑,文档写的跟狗屎一样,什么都想做,还什么都做不好,感觉这玩意就不该出现,完全是适配各种奇葩需求出来的不伦不类的东西。 - capacitor 相当健壮,文档清晰明了,各种系统层面的插件非常明了。https://capacitorjs.com/ - ReactNative 不熟,只用它写过一个纯壳子,不多作评价。 归总起来就是,用网页做类似 app 的东西,挺麻烦,这个过程是非常不愉快的。如果只是在网页层面实现的功能,那还差不多。 |
9
aahao 2023-12-18 09:40:58 +08:00
React Native
|
10
duanxianze 2023-12-18 09:46:10 +08:00
你这种就是 Uniapp 最好了,不要想着啥类原生,直接就是小程序,类似微信小程序就行了
|
11
datoujiejie221 2023-12-18 09:57:27 +08:00
当年因为 vue 的技术栈,还用过阿里的 weex ,然后就不维护了,好像 uniapp 的 nvue 就是基于 weex 改进的,其实 weex 的设计思想还是可以的,就是国内的开源生态还是太差了。
基于 js 的跨端技术感觉都是越到后面坑越多,建议还是用网页开发。 |
13
murmur 2023-12-18 10:04:50 +08:00
那就给他原生做个登录页面,还有那种 header+tab 的页面,中间套 webview ,不让上架的是 webview+远程,又不是本地资源
|
14
vishun 2023-12-18 10:05:08 +08:00
`有没有办法浏览打开的时候隐藏工具栏和地址栏`h5 的话这个应该不行,你一个网页哪有权限来做这些东西,就算某些浏览器开放了这个接口,能保证用户都会用这个浏览器吗?而 pws 是依赖浏览器的,谁能保证客户一定会在提示时就添加为 pwa 呢?感觉要实现这些功能,要么小程序要么开发 app 。
|
15
wolfan 2023-12-18 10:07:31 +08:00
有个问题,你们的用户是国内用户还是国外用户。或者说国产机( MI\H\O\V )为主还是三星、水果为主。
如果是国内的话,PWA 其实不合适,因为国产品牌对 PWA 是各有不同的腌制。而是单独搞了一个‘轻应用联盟’,轻应用和 PWA 差不多,但调用的资源更多一些。所以如果是国产为主就上轻应用,如果还要兼顾水果、三星这些就需要单独维护个 PWA 。 |
16
monologue520 2023-12-18 10:16:06 +08:00
RN
|
17
wa143825 2023-12-18 11:09:32 +08:00
体验过 2 个 uniapp 开发的大型 app
我们的 OA 系统,功能非常多,是要代替钉钉的,卡的不要不要的。 给华润做项目外包时,他们的移动端报表平台,感觉不如直接用浏览器。 |
18
bu9 2023-12-18 11:10:53 +08:00
X + webview + jsBridge + html5
|
19
sundev 2023-12-18 11:11:58 +08:00
最近也在弄这个,最初跟你的想法一样,想上 flutter ,后来初期验证后感觉前端想直接上手 flutter 还是有难度的。
后来我直接使用 vue+vant 一把梭,然后使用 capacitor 来打包一下,一般使用没有问题。如果交互场景复杂,那么 web 套壳肯定不行了。 |
20
vaccer 2023-12-18 11:19:55 +08:00 via iPhone
写过一个 uniapp 项目,那体验一言难尽。
后来推翻用 react-native 重做了 |
21
meteor957 2023-12-18 11:24:30 +08:00 via Android
React Native
|
22
southsala 2023-12-18 16:45:48 +08:00
你想用前端的技术栈还想要客户端的效果只能用 React-Native 。
|
23
zhoushuo 2023-12-18 16:59:58 +08:00
用 uniapp 开发过两三个项目,说实话开发体验有点糟糕,app 的使用体验和原生也有一定差距,建议用 RN
|
24
daviszhang OP 谢谢各位大哥们的回复,uniapp 不写小程序就不考虑了
现在还是倾向于 pwa 。pwa 基本满足我们的需求 React-Native:团队没有兴趣学 react ,更倾向于 vue 框架 (毕竟是国人参与开发) capacitor:这个很有兴趣,如果要打包的话,肯定很有用 原生做个登录页面: 团队的人不会原生开发的,要学习又得学新语言和布局方式,真要用原生我觉得不如直接学 flutter ,毕竟性能上不要求太高 |
25
daviszhang OP @kylebing 谢谢老哥,capacitor 提供了另一种思路
|
26
daviszhang OP @vishun 单纯的 js 确实做不到,不过 pwa 倒是可以,前提需要用户打开网页和安装
|
27
jamesjammy061 285 天前
@kylebing 老哥,感谢分享。想问一下 用 expo 作为壳咋样?其实想实现和 capacitor 差不多的效果,但是生态感觉要好很多,而且一定程度上可以自己 DIY 壳
|