CSS 问题,不用 display:flex 是否能实现这个功能?

2020-02-25 16:04:44 +08:00
 nikoo
一个不定长的 div,里面包含一个 input 与一个提交按钮,要求 input 可以自适应宽度
有可能不用 flex 实现这个功能吗?

例子: https://jsfiddle.net/ko08g7za/
(左右拖动改变窗口宽度可以看到 input+button 始终能占满 div )
2025 次点击
所在节点    问与答
25 条回复
GDC
2020-02-25 16:12:21 +08:00
可以,方法有很多,比如 input 的宽度用 calc() 计算,就看你不用 flex 的原因是啥了
fanxingyu9555666
2020-02-25 16:14:43 +08:00
Calc 计算宽度
nikoo
2020-02-25 16:15:23 +08:00
@GDC 是考虑浏览器兼容性(是否想多了?)
nikoo
2020-02-25 16:16:21 +08:00
@fanxingyu9555666 如果是考虑浏览器兼容性那似乎还不如 flex ?
Steps
2020-02-25 16:17:07 +08:00
当然可以。。。
<div style="display: flex;">
<div style="flex: 1;width: 100%;"><input style="width: 100%;"></div>
<div style="width: 80px;"><button type="button" style="width: 100%">按钮</button></div>
</div>
nikoo
2020-02-25 16:18:22 +08:00
@Steps 这不还是用 display:flex ?
GDC
2020-02-25 16:18:27 +08:00
@nikoo 考虑浏览器兼容性,要看你的用户群体是什么,准备兼容到 IE 几,你去看看 Bootstrap 4 用了多少 flex,关键还是看网站的用户群体
wunonglin
2020-02-25 16:18:39 +08:00
你这个例子就是 ok 的啊,什么年代了还有不支持 flex 的么,ie 不是浏览器
loading
2020-02-25 16:22:23 +08:00
既然没说不能加 js,那不就几行么。
whypool
2020-02-25 16:22:33 +08:00
都什么年代了还不能用 flex ?
ie 不是浏览器
RtIHZ
2020-02-25 16:23:00 +08:00
cmdOptionKana
2020-02-25 16:23:25 +08:00
@nikoo 这也算一种过早优化了,先上线,后台统计访问你们页面的都有哪些浏览器,然后再决定需要适配到什么程度。
liyang5945
2020-02-25 16:24:39 +08:00
最简单的,父 div 设置一个右 padding,宽度比按钮稍宽一些,设置相对定位,里面的 input 设置宽度 100%,提交按钮设置绝对定位
nikoo
2020-02-25 16:27:14 +08:00
@liyang5945 好办法!谢谢!
darmau
2020-02-25 16:27:38 +08:00
现在真的很难找到不支持 flexbox 的浏览器了
geelaw
2020-02-25 16:30:47 +08:00
用 display: table 也可以
learnshare
2020-02-25 16:33:11 +08:00
flex 出现之前有很多方法,flex 出现之后就只推荐 flex 了
netnr
2020-02-25 16:47:54 +08:00
lneoi
2020-02-25 17:09:43 +08:00
外层用 div 包裹 input 和 button,button 用 position:absolute 右侧,这样可以写死大小。左侧 input 设置 100%,然后 div 给一个 padding-right 大小稍大于 button 的大小
两个都是动态大小会更方便点
yimity
2020-02-25 17:12:31 +08:00
如果你 button 可以固定宽度的话,可以尝试定位的方式。当然了 100% 布局也是可以的。
https://jsfiddle.net/f0dLxcpb/

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

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

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

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

© 2021 V2EX