CSS scale height to match width - possibly with a formfactor

前端 未结 10 1734
天涯浪人
天涯浪人 2020-12-04 11:28

I have implemented a GoogleMapsV3 map in a twitterBootstrap basic responsive design site.

But my question is quite simple: i have:

相关标签:
10条回答
  • 2020-12-04 11:31

    Here it is. Pure CSS. You do need one extra 'container' element.

    The fiddle

    (tinkerbin, actually): http://tinkerbin.com/rQ71nWDT (Tinkerbin is dead.)

    The solution.

    Note I'm using an 100% throughout the example. You can use whichever percentage you'd like.

    Since height percentages are relative to the height of the parent element, we can't rely on it. We must rely on something else. Luckily padding is relative to the width - whether it's horizontal or vertical padding. In padding-xyz: 100%, 100% equals 100% of the box's width.

    Unfortunately, padding is just that, padding. The content-box's height is 0. No problem!

    Stick an absolutely positioned element, give it 100% width, 100% height and use it as your actual content box. The 100% height works because percentage heights on absolutely positioned elements are relative to the padding-box of the box their relatively positioned to.

    HTML:

    <div id="map_container">
      <div id="map">
      </div>
    </div>   
    

    CSS:

    #map_container {
      position: relative;
      width: 100%;
      padding-bottom: 100%;
    }
    
    #map {
      position: absolute;
      width: 100%;
      height: 100%;
    }
    
    0 讨论(0)
  • 2020-12-04 11:32

    For this, you will need to utilise JavaScript, or rely on the somewhat supported calc() CSS expression.

    window.addEventListener("resize", function(e) {
        var mapElement = document.getElementById("map");
        mapElement.style.height = mapElement.offsetWidth * 1.72;
    });
    

    Or using CSS calc (see support here: http://caniuse.com/calc)

    #map {
        width: 100%;
        height: calc(100vw * 1.72)
    }
    
    0 讨论(0)
  • 2020-12-04 11:36
    #map { 
        width: 100%; 
        height: 100vw * 1.72 
    }
    
    0 讨论(0)
  • 2020-12-04 11:38

    You could try using vw for height. https://developer.mozilla.org/en/docs/Web/CSS/length

    Something like

    div#map {
         width: 100%;
         height: 60vw;
    }
    

    This would set the width of the div to 60% of the viewport width. You will probably need to use calc to adjust to take padding into account …

    0 讨论(0)
  • 2020-12-04 11:39

    Try viewports

    You can use the width data and calculate the height accordingly

    This example is for an 150x200px image

    width: calc(100vw / 2 - 30px);
    height: calc((100vw/2 - 30px) * 1.34);
    
    0 讨论(0)
  • 2020-12-04 11:39

    I need to do "fluid" rectangles not squares.... so THANKS to JOPL .... didn't take but a minute....

    #map_container {
         position: relative;
         width: 100%;
         padding-bottom: 75%;
    }
    
    
    #map {
        position:absolute;
        width:100%;
        height:100%;
    }
    
    0 讨论(0)
提交回复
热议问题