用 vue 开发一个项目,需要同时适应 pc 和移动端。

2020-09-01 15:41:01 +08:00
waiaan  waiaan

业务逻辑都是一样的,只有页面布局和样式不一样,这种要怎么处理? 谢谢。

5978 次点击
所在节点   Vue.js  Vue.js
22 条回复
tutuk5
tutuk5
2020-09-01 16:07:22 +08:00
分 2 套模版,入口就当作 pc 端,判断一下设备类型,mobile 跳转另一套
qq316107934
qq316107934
2020-09-01 16:08:48 +08:00
做响应式就可以了,设置不同页面宽度下具体 grid 占用 col 的数量。
loading
loading
2020-09-01 16:09:01 +08:00
要求低就弹性布局,要求高不用说啦。
redbuck
redbuck
2020-09-01 16:11:51 +08:00
让 UI 设计时注意按功能划分区块.

然后媒体查询实现一个布局组件,业务组件统统用布局组件包起来.

不过要注意交互逻辑是否一致.
比如桌面的分页加载,放到移动端一般是上拉加载,这两个加载逻辑不一致,在此基础上的增删改查处理方式也不一致.
lbw
lbw
2020-09-01 16:11:55 +08:00
css media query + flex box 或 grid box
murmur
murmur
2020-09-01 16:15:51 +08:00
移动端和 pc 端布局可差远了
luckyrayyy
luckyrayyy
2020-09-01 16:18:39 +08:00
响应式很难驾驭的,多半情况下设计出来是两个端都不太好用....
gloye
gloye
2020-09-01 16:40:47 +08:00
vuetify 了解一下
waiaan
waiaan
2020-09-01 16:45:05 +08:00
@tutuk5 业务逻辑这一块怎么处理?两套都是一样的业务代码。

@redbuck 业务逻辑的代码一模一样,只有布局上的不同,比如移动端表格可能只展示某几列,不用全部展示。
ruoxie
ruoxie
2020-09-01 17:24:20 +08:00
逻辑复用可以考虑上 hooks
zaul
zaul
2020-09-01 17:33:22 +08:00
2 套模板,PC 一套,mobile 一套,根据设备类型跳转
miv
miv
2020-09-01 17:46:57 +08:00
@waiaan 计算属性或者 vif 判断
xianqin
xianqin
2020-09-01 18:08:50 +08:00
css 媒体查询走一波?
yiyi11
yiyi11
2020-09-01 18:16:35 +08:00
一套代码,只能移动端优先,然后把 pc 当成“大屏手机”。
darknoll
darknoll
2020-09-01 18:22:31 +08:00
用 material 风格的组件库吧,移动端和 pc 都适配
sunzongzheng
sunzongzheng
2020-09-02 00:17:19 +08:00
做个入口组件?

export default {
component: {
PC: require.ensure('xx') // 懒加载
H5: require.ensure('xx') // 懒加载
},
render(h) {
if(pc) return h('PC')
else return h('H5')
}
}
KisekiRemi
KisekiRemi
2020-09-02 02:51:10 +08:00
媒体查询 @media
再加一个移动端查询
KisekiRemi
KisekiRemi
2020-09-02 02:52:25 +08:00
@KisekiRemi 最好用流行的 ui 库
meteor957
2020-09-02 09:05:02 +08:00
很简单的话就响应式,最好写两套代码
ksice
2020-09-02 10:14:45 +08:00
然后 pc 端还需要适用 ie 浏览器(狗头保命)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/703182

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX