鍍金池/ 問答/HTML/ css 在寬度都不清楚的情況下怎么自適應

css 在寬度都不清楚的情況下怎么自適應

clipboard.png

我想把中間input 的div 寬度自適應需要怎么做? 在總寬度不知道的情況下 有沒有什么好的辦法

  <header class="header-div">
      <div class="header-top">
        <div class="header-img">
          <img src="../../static/position.png" alt="" style="margin-top: -5px">
        </div>
        <span>宜昌</span>
        <div>
          <div class="header-img">
            <img src="../../static/searrch.png" alt="">
          </div>
          <input type="text" placeholder="搜索個關(guān)鍵詞試試">
        </div>
        <div class="header-img">
          <img src="../../static/email.png" alt="" >
        </div>
      </div>
    </header>

兩邊的寬度我設(shè)定的是rem 所以不知道具體是多少

/*** rem的換算   用的scss ***/
@function px2rem($px, $base-font-size: 75px) {
    @return ($px / $base-font-size) * 1rem;
}
/*** rem的換算 end ***/

//兩邊的寬度都是這樣設(shè)置的
.div {
        width: px2rem(40px);
        height: px2rem(40px);

 }

我總不能給中間的div設(shè)置寬度

width: calc(100% - px2rem(XXX));

....
求各位大佬幫我看看

回答
編輯回答
她愚我

calc了解一下

2017年2月23日 09:47
編輯回答
尛憇藌

解決方案
考慮兼容性問題,希望能做到兩邊定寬,中間自適應可以考慮:
1)圣杯布局 —— 來自國外文章,In Search of the Holy Grail一文
2)雙飛翼布局 —— 來自淘寶
注明:這兩個布局,也是前端招聘中常見的問題,值得去做一個深入的理解。

解決方案優(yōu)缺點
1、圣杯布局
1)優(yōu)點:兼容所有瀏覽器、不用JS計算中間容器寬度就能自適應、優(yōu)先使中間部分得到渲染。
2)缺點:需要在左中右DIV外添加一層“包裹層”。

2、雙飛翼布局
1)優(yōu)點:兼容所有瀏覽器、不用JS計算中間容器寬度就能自適應、優(yōu)先使中間部分得到渲染、實現(xiàn)不同的布局方式,可以通過調(diào)整相關(guān)CSS屬性即可實現(xiàn)。
2)缺點:需要在中間DIV外添加一層“包裹層”。

兩種布局方式的主要差別,集中在于其實現(xiàn)的思想上的不同。希望了解到更多相關(guān)知識,可以查看https://www.zhihu.com/questio...

2018年6月19日 23:58
編輯回答
不將就

calc(100% - 左右兩邊的圖和文字的寬度)

2018年6月16日 13:29
編輯回答
忘了我

這個其實和圣杯布局的意思差不多啊,
不考慮兼容性的話,使用flex實現(xiàn),可以百度下,很簡單
考慮兼容性的話,使用float

例如,你有兩列,左邊固定200px,右邊占滿,
那就讓右邊元素-margin等于左邊的元素,這樣元素就可以上去了,
同時padding-left設(shè)置為左邊元素寬度,這樣就不占用左邊元素的空間了

.left {
  float: left;
  width: 200px;
  height: 100%;
}
.right {
  width: 100%;
  float: left;
  margin-left: -200px;
  padding-left: 200px;
}
2017年3月25日 21:07