edit: применение min-height: 0;
к .svg-container
фиксирует размеры контейнера, но в Edge элементы svg переполняют их контейнеры.
Я пытаюсь масштабировать встроенный элемент SVG до высоты его родительского контейнера. Размер родительского контейнера определяется по сетке CSS (я также пробовал flex box).
Мне удалось настроить эту функцию при просмотре в Google Chrome, установив для свойства elements max-height
значение 100%
. Однако при просмотре в других браузерах SVG, похоже, игнорирует это правило.
Это браузеры, которые я пробовал:
- Google Chrome: версия 80.0.3987.87 (Официальная сборка) (64-разрядная версия) - эта работает
- Microsoft Edge: 44.18362.449.0
- Firefox Developer Edition: 73.0b12 (64-разрядная версия)
- Firefox: 72.0.2 (64-разрядная версия)
Вот как это выглядит в Google Chrome (желаемый результат):
Вот как это выглядит в FFDE (также в обычном FF & Edge):
Оба элемента body
и html
имеют правило height: 100vh;
и все другие дочерние размеры получены из %
или fr
.
Я был бы очень признателен за любые указания относительно того, как обеспечить, чтобы элементы не превышали 100% своих родительских контейнеров, когда контейнеры при использовании css grid или flex, так как до сих пор ни одно из решений, которые я нашел в других потоках, не работало для меня.
Вот jsfiddle и ниже я включу код. Спасибо за ваше время.
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html,
body {
width: 100vw;
height: 100vh;
font-family: Arial, Helvetica, sans-serif;
display: flex;
justify-content: center;
}
.container {
display: grid;
grid-template-rows: 1fr 2fr 3fr;
width: 100%;
max-height: 100%;
max-width: 540px;
}
.svg-container {
border: 1px solid black;
}
svg {
width: 100%;
height: 100%;
max-height: 100%;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<link rel="stylesheet" href="style.css">
<title>Document</title>
</head>
<body>
<div class="container">
<div class="svg-container">
<svg viewBox='0 0 3.904897 29.412678' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'>
<path
d='M 0,25.550255 V 3.8624222 H 2.01753 V 25.550255 H 0 m 2.850575,3.862422 H 2.551199 C 1.142257,29.412677 0,27.979719 0,26.211588 v -0.661333 h 2.01753 v 0.981485 c 0.0024,0.884983 0.574154,1.599169 1.2756,1.593463 h 0.611767 v 1.287474 z M 2.850575,0 H 2.5512 C 1.142257,0 0,1.4329586 0,3.2010897 V 3.8624222 H 2.01753 V 2.8809378 C 2.01993,1.9959549 2.591684,1.2817684 3.29313,1.2874741 H 3.904897 V 0 Z' />
</svg>
</div>
<div class="svg-container">
<svg viewBox='0 0 3.904897 29.412678' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'>
<path
d='M 0,25.550255 V 3.8624222 H 2.01753 V 25.550255 H 0 m 2.850575,3.862422 H 2.551199 C 1.142257,29.412677 0,27.979719 0,26.211588 v -0.661333 h 2.01753 v 0.981485 c 0.0024,0.884983 0.574154,1.599169 1.2756,1.593463 h 0.611767 v 1.287474 z M 2.850575,0 H 2.5512 C 1.142257,0 0,1.4329586 0,3.2010897 V 3.8624222 H 2.01753 V 2.8809378 C 2.01993,1.9959549 2.591684,1.2817684 3.29313,1.2874741 H 3.904897 V 0 Z' />
</svg>
</div>
<div class="svg-container">
<svg viewBox='0 0 3.904897 29.412678' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'>
<path
d='M 0,25.550255 V 3.8624222 H 2.01753 V 25.550255 H 0 m 2.850575,3.862422 H 2.551199 C 1.142257,29.412677 0,27.979719 0,26.211588 v -0.661333 h 2.01753 v 0.981485 c 0.0024,0.884983 0.574154,1.599169 1.2756,1.593463 h 0.611767 v 1.287474 z M 2.850575,0 H 2.5512 C 1.142257,0 0,1.4329586 0,3.2010897 V 3.8624222 H 2.01753 V 2.8809378 C 2.01993,1.9959549 2.591684,1.2817684 3.29313,1.2874741 H 3.904897 V 0 Z' />
</svg>
</div>
</div>
</body>
</html>