Я видел решение для высоты в зависимости от ширины: css height same as width. Или здесь: https://stackoverflow.com/a/6615994/2256981. Но мой вопрос противоположный.Ширина установки в зависимости от высоты
Мой элемент:
<body>
<div id="square"></div>
</body>
Стиль для нее:
body, html {
margin: 0;
height: 100%;
min-height: 300px;
position: relative;
}
div#square { /* My square. */
height: 75%; /* It's height depends on ancestor's height. */
width: 75vh; /* If supported, preliminarily sets it's width. */
position: absolute; /* Centers it. */
left: 50%; top: 50%; transform: translate(-50%, -50%);
background-color: darkorange; /* Makes it visible. */
}
Сценарий, который держит его квадрат:
window.onload = window.onresize = function (event) {
var mySquare = document.getElementById("square");
mySquare.style.width = mySquare.offsetHeight + 'px';
};
Полный код здесь: http://jsfiddle.net/je1h/hxkgfr9g/
вопросзаключается в том, чтобы сделать то же самое в чистом CSS. Нет сценариев.
Я не знаю, можете ли вы сделать это в css. Вы можете попробовать https://css-tricks.com/snippets/css/a-guide-to-flexbox/, но я не знаю, поможет ли это вам. – xdhmoore
Это делает то, что вы ищете? http://stackoverflow.com/questions/12899031/css-squares-on-resize – xdhmoore
Я также думаю, что это невозможно в чистом CSS, много раз пробовали ... Нам придется подождать, прежде чем стилизовать динамические совершенные квадраты! Единственный вариант, который я вижу, это Javascript, как вы на самом деле писали. – Sebastien