解决label和input在一行放不下时同时换行的问题

本文介绍了解决Label和Input在同一行无法完全显示时,如何通过CSS的white-space属性设置,实现两者同时换行的方法。

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

解决label和input在一行放不下时同时换行的问题

上问题:

可以看到我们以图中红色框框起来的为一组,当前的状态的各自安好的 ,但好景不长,对于一些国际化的项目必须去适配多语言的系统,就导致会出现筛选项的名字长度无法确定在固定的范围,从而导致如下图的情况:

可以看到我们的问题就来了,黄色的区域的内容原本应该是成对存在的,在一行无法放下的时候最好的解决方法是两个一起到下一行 (在要求label必须全部展示完整名字的情况下)

那么如何解决呢:我们可以看到原先的代码例如Bootstrap

<!-- Bootstrap 提供的代码 -->
<form class="form-inline">
  <div class="form-group">
    <label for="exampleInputName2">Name</label>
    <input type="text" class="form-control" id="exampleInputName2" placeholder="Jane Doe">
  </div>
  <div class="form-group">
    <label for="exampleInputEmail2">Email</label>
    <input type="email" class="form-control" id="exampleInputEmail2" placeholder="jane.doe@example.com">
  </div>
  <button type="submit" class="btn btn-default">Send invitation</button>
</form>

博主原代码段:

<!-- 博主源码(改前)  -->
<div class="form-group " style="display: inline;">
      <label style="font-weight: 400;margin-left: 1%;" class="control-label ">TESTNAMETESTlooooooooooongName</label>
                <input type="text" class="form-control " placeholder="Search something..."
                   >
            </div>
            <div class="form-group "  style="display: inline;"> 
                <label style="font-weight: 400;margin-left: 1%;" class="control-label" for="sel_a">TESTNAMETENAMElooooooooooongName</label>
                <select id="sel_a" class="selectpicker show-tick" data-width="15%" data-live-search=“true”>
                    <option value="">Please select ...</option>
                    <option>Algoblu</option>
                    <option>HA</option>
                    <option>CMCC</option>
                </select>
            </div>
            <div class="form-group"  style="display: inline;"> 
                <label style="font-weight: 400;margin-left: 1%;" class="control-label " for="sel_b">TESTNAMENAMElooooooooooongName</label>
                <select id="sel_b" class="selectpicker show-tick " data-width="15%">
                    <option value="">Please select ...</option>
                    <option>A001</option>
                    <option>A002</option>
                    <option>A003</option>
                </select>
            </div>
            <button id="btn" type="button" class="btn btn-info" autocomplete="off">
                查询
            </button>

那么重点来了;我们如何对相关联的项进行捆绑,“一荣俱荣,一损俱损”呢?

知识点1:盒子的宽度与高度问题

审查元素可以看到(以最后一组为例)两个在同一个div里,但没有固定的宽度和高度 所以后面的select框实际上是进行了换行处理  既然问题找到了解决问题

 知识点2:CSS对盒子内换行的问题

white-space 

对就是他一个知识点解决关键问题

这个属性原本在设计的时候是服务于P段落标签的但在此刻巧妙地运用让他熠熠生辉,既然提到了就复习或预习一下他

回到正题哦,我们只要在盒子上加上不允许换行就可以解决我们的当前问题

上效果:

解决问题妥妥的!!

上代码:

 <div class="form-group"  style="display: inline;white-space:nowrap;"> 
                <label style="font-weight: 400;margin-left: 1%;" class="control-label ">TESTNAMETESTlooooooooooongName</label>
                <input type="text" class="form-control " placeholder="Search something..."
                   >
            </div>
            <div class="form-group"  style="display: inline;white-space:nowrap;"> 
                <label style="font-weight: 400;margin-left: 1%;" class="control-label" for="sel_a">TESTNAMETENAMElooooooooooongName</label>
                <select id="sel_a" class="selectpicker show-tick" data-width="15%" data-live-search=“true”>
                    <option value="">Please select ...</option>
                    <option>Algoblu</option>
                    <option>HA</option>
                    <option>CMCC</option>
                </select>
            </div>
            <div class="form-group"  style="display: inline;white-space:nowrap;"> 
                <label style="font-weight: 400;margin-left: 1%;" class="control-label " for="sel_b">TESTNAMENAMElooooooooooongName</label>
                <select id="sel_b" class="selectpicker show-tick " data-width="15%">
                    <option value="">Please select ...</option>
                    <option>A001</option>
                    <option>A002</option>
                    <option>A003</option>
                </select>
            </div>
            <button id="btn" type="button" class="btn btn-info" autocomplete="off">
                查询
            </button>

好了,就是这些啦,你学废了吗?

(原谅博主的罗里吧嗦,毕竟这篇文章是博主开号三年来的第一篇)

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值