有个关键问题,第二排按钮会捅到支付方式下边
![]() | 1 Asakijz 2023-07-13 10:55:00 +08:00 没看懂需求 |
2 wednesdayco 2023-07-13 10:55:58 +08:00 能,话说你这按钮的大小不会不一致吧? |
![]() | 3 pengtdyd 2023-07-13 10:59:00 +08:00 可以,但是你能问出这个问题,我感觉你写不出来。 |
![]() | 4 vitovan 2023-07-13 10:59:37 +08:00 .container { display: flex; flex-direction: row-reverse; flex-wrap: wrap; } 这行吗? |
![]() | 5 LaGeNanRen 2023-07-13 10:59:48 +08:00 ![]() 在座的各位有几个听懂他的需求和问题了 :) |
6 wednesdayco 2023-07-13 11:05:37 +08:00 @LaGeNanRen 我猜他说的是按钮数据是个数组,布局的时候分成两排。 实现方式多得很 |
![]() | 7 MRG0 OP @wednesdayco 不一致,有大有小,甚至顺序也有要求 |
![]() | 9 MRG0 OP @wednesdayco #6 分布成两排倒是好实现,但是如何让第二排按钮一直可以前伸到支付方式下边呢 |
![]() | 10 admol 2023-07-13 11:09:24 +08:00 ![]() 让我想到了在地图上打电话的那个,你应该先这样,再这样,然后再这样,最后再这样,不就可以了吗 |
14 ZGame 2023-07-13 11:13:22 +08:00 你要求后端返回的不同数组 对应不同的 type 不就行了, 生成不同的模板组件... |
15 wednesdayco 2023-07-13 11:13:48 +08:00 @MRG0 按钮大小不固定的话我目前只能想到把按钮单独放到一个容器里面,然后将其绝对定位覆盖在支付方式容器,第一个按钮 width100%占满换行第二排 |
16 ZGame 2023-07-13 11:14:01 +08:00 type => itemWarpperContainerOneStyle ,Two,Three........ |
![]() | 17 sankemao 2023-07-13 11:14:45 +08:00 你把支付方式和按钮再用 flex 左右套下不就行了 |
![]() | 18 hlwjia PRO 嘛,写 4 个 switch case 好了 |
![]() | 19 me1onsoda 2023-07-13 11:15:25 +08:00 这个不就是靠右,然后自动换行嘛 |
![]() | 20 QUC062IzY3M1Y6dg 2023-07-13 11:19:47 +08:00 这应该就是个纯粹的 css 问题,但是我没太能理解 op 想要的布局到底什么,看完图我更困惑了 |
![]() | 21 sgiyy 2023-07-13 11:24:14 +08:00 |
![]() | 22 wusheng0 2023-07-13 11:26:57 +08:00 四种支付方式? 第二排按钮会捅到支付方式下边,什么是捅,想象不出来,第二排按钮说的是哪个? |
![]() | 23 acvvkhalil 2023-07-13 11:26:57 +08:00 太容易了啊, 怎么实现都行, 你先左右, 然后右边在让它换行也行, 不让就第一个按钮和支付方式当行, 把剩余的放下面一行不就好了 |
24 AndrewAdam 2023-07-13 11:27:48 +08:00 理解不能 去喷交互设计师 |
![]() | 25 dudubaba 2023-07-13 11:31:43 +08:00 简单,你猜 css 选择器 nth-child 是干嘛的 |
27 wednesdayco 2023-07-13 11:32:44 +08:00 ![]() |
![]() | 28 jy02534655 2023-07-13 11:34:25 +08:00 flex 布局实现不了的可以试试 grid 布局 |
![]() | 29 MRG0 OP @dudubaba stylus 下 nth-child 选择器居然不起效, 写法: .a{ width 100% height 102px &:nth-child(1){ background #123456 } } |
![]() | 30 darkengine 2023-07-13 11:35:37 +08:00 楼上老哥已经解释得很清楚了,先拆了左右两列,再在右边那一列对支付方式按钮进行布局 |
![]() | 31 MRG0 OP @wednesdayco #27 这也太牛了吧 |
32 wednesdayco 2023-07-13 11:39:43 +08:00 @MRG0 只是个意思 你可以再发散下 |
![]() | 33 MRG0 OP @wednesdayco #32 多谢,心里有数了 |
![]() | 35 RATIONALITY 2023-07-13 11:46:23 +08:00 ![]() @wednesdayco #27 你舅宠他爸 |
38 Dongpenghui 2023-07-13 13:20:29 +08:00 display:grid 布局,你去研究一下 |
![]() | 39 MRG0 OP |
![]() | 40 mingl0280 2023-07-13 13:33:49 +08:00 via Android 横着拆也可以,两行,第一行两列,第二行 flex ,按钮 1 右对齐,剩下的想咋排咋排 |
![]() | 41 MarkP 2023-07-13 13:35:01 +08:00 @wednesdayco #27 饭喂到嘴边不过如此了 |
![]() | 42 sgiyy 2023-07-13 13:50:25 +08:00 @MRG0 #26 那也没必要太复杂的布局,上下布局即可。第一行只有一个按钮就取数组的第一项(按钮右边,支付方式左边);数组的剩余项再遍历成第二行。 |
![]() | 44 asdjgfr 2023-07-13 14:21:09 +08:00 |
45 MMDeJeVS3GtMVLeu 2023-07-13 14:25:47 +08:00 |
![]() | 46 asdjgfr 2023-07-13 14:38:49 +08:00 刚才没仔细看,这个应该满足 ui 的需求了 https://codesandbox.io/s/sleepy-lumiere-28khrx?file=/src/App.vue |
47 jiqiren 2023-07-13 14:41:42 +08:00 看懂了,但没完全懂.... |
![]() | 48 Alander 2023-07-13 15:41:38 +08:00 这个问题简单抽象一下就好了吧? 从 ui 层面上看 就是 第一行永远存在,第二行可能不存在 判断条件是按钮个数 第一行永远只会有一个按钮,这个按钮是最长的按钮 两个 div 第一个是 flex ,第二个直接 text-align:right 就完事了 |
49 Seanfuck 2023-07-13 15:42:06 +08:00 非要 flex 吗?普通方式很简单的: 先 js 排序拿出长的; 然后弄两个 div ,第一 div 放支付方式,长的按钮 float:right; 第二 div 里放剩下的按钮,也是 float:right ,div 加上 overflow |
![]() | 53 MRG0 OP 现在主要是两种方案: |
![]() | 54 MRG0 OP @MRG0 #53 1 ,使用想对布局,这样可以保留”循环数组“这一特点,就是调样式麻烦一点 2 ,数据分两行,这样布局简单,但我不敢确定能否应对后端传回来的数组里的所有情况 |
![]() | 55 hevi 2023-07-13 16:39:51 +08:00 认同#49 ,数组第一个单独处理,二及之后 flex 完事 |
![]() | 56 hevi 2023-07-13 16:44:50 +08:00 如果用 tailwindcss ,可以参考 ``` <div class="flex h-screen w-screen items-center justify-center"> <div class="w-[520px] p-8"> <div class="mb-4 flex justify-between gap-4 border p-4"> <div class="shrink-0 text-gray-600">支付方式</div> <div> <div class="flex justify-end mb-2"> <div class="border border-blue-400 p-2 text-sm text-gray-600">按钮 11111111111111</div> </div> <div class="flex flex-wrap justify-end gap-4"> <div class="border border-blue-400 p-2 text-sm text-gray-600">按钮 222</div> <div class="border border-blue-400 p-2 text-sm text-gray-600">按钮 333</div> <div class="border border-blue-400 p-2 text-sm text-gray-600">按钮 444</div> <div class="border border-blue-400 p-2 text-sm text-gray-600">按钮 555</div> </div> </div> </div> </div> </div> ``` |
![]() | 57 MENGKE 2023-07-13 16:46:27 +08:00 ![]() 先排个序,然后 flex ,然后 [支付方式] 算第一条加进去,支付方式用 justify-self: flex-start ;其他的 flex-end; |
![]() | 59 hevi 2023-07-13 16:51:48 +08:00 @MRG0 对着官网,按/查想要的 style 属性,用多了就香了 你可以复制前面那代码到 https://play.tailwindcss.com/ 去看看效果 官网 https://tailwindcss.com/docs/installation 大陆 https://www.tailwindcss.cn/docs/installation |
60 gerorge 2023-07-13 16:52:44 +08:00 @LaGeNanRen 完全看不懂 |
![]() | 61 CHTuring 2023-07-13 17:00:07 +08:00 这和你什么布局都没关系,flex 也行 grid 也行,float 也行,只是对数量进行判断加 class 而已 |
![]() | 62 plasticman64 &bsp;2023-07-13 17:03:32 +08:00 应该没有 FLEX 实现不了的布局 |
![]() | 64 hevi 2023-07-13 17:15:00 +08:00 @MRG0 额,你还可以这么写,第二个开始,前面加个 width:100%的元素,隔开,做到换行的效果。 如果第二行开始需要两端对齐的话,那还是隔开处理吧。 ``` <div class="flex h-screen w-screen items-center justify-center"> <div class="w-[600px] p-8"> <div class="mb-4 flex justify-between gap-4 border p-4"> <div class="shrink-0 text-gray-600">支付方式</div> <div class="flex-grow flex flex-wrap justify-end"> <div class="border border-blue-400 p-2 text-sm text-gray-600 mb-2">按钮 11111111111111</div> <div class="w-full"></div> <div class="border border-blue-400 p-2 text-sm text-gray-600 mr-2">按钮 222</div> <div class="border border-blue-400 p-2 text-sm text-gray-600 mr-2">按钮 333</div> <div class="border border-blue-400 p-2 text-sm text-gray-600 mr-2">按钮 444</div> <div class="border border-blue-400 p-2 text-sm text-gray-600">按钮 55555555</div> </div> </div> </div> </div> ``` |
65 pianjiao 2023-07-13 18:20:17 +08:00 先 js 判断返回值的列表里面按钮的长度,如果长的在上面 就洗一下数据,页面在根据 flex 获取 gird 来布局 |
![]() | 66 shoto 2023-07-13 19:33:49 +08:00 via Android 感觉没见个看懂你需求的。 去喷你们交互设计吧。设计的什么玩艺儿。缺心眼。 长按钮一定要在第一行, 第二行要通到支付文 字下面。 我能想到的就是 数组要按字符串长度排序, 然后 flex 主轴从下向上,按钮从右下开始对齐,从右向左排,向上折行。但长按钮一定保持在第一行没想到办法。 而且如果按钮超多会盖住 支付文字。支付文字做 div 背景层处理。 |
![]() | 67 zhw2590582 2023-07-13 23:53:45 +08:00 哈哈,我还是没理解你的意思 |
![]() | 68 b0x 2023-07-14 02:00:27 +08:00 1. 通过 js, 根据按钮的内容长度对按钮的顺序进行排序, 从而决定哪个按钮出现在第一排. 2. 剩下的事情 css 的 flex 搞定即可. 另外,如果一组按钮的先后顺序是和按钮内容的长度有关,那么说明 UI 交互逻辑设计是有问题的. |
![]() | 69 davin 2023-07-14 07:28:38 +08:00 就是个原型图而已,设计师也不会直接这么设计的。问问你的设计师同事比较靠谱。 |
![]() | 70 RyougiShiki 2023-07-14 08:08:23 +08:00 不给 27 楼点个赞吗 |
![]() | 71 MRG0 OP @RyougiShiki 狠狠的赞住了 |