Diskuze: Rozvržení stránky bez JavaScriptu
V předchozím kvízu, Online test znalostí HTML a CSS, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 16 zpráv z 16.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí HTML a CSS, jsme si ověřili nabyté zkušenosti z kurzu.
EDIT: aha, až teraz som si všimol tvoj problém.
Jedno z riešení: https://jsfiddle.net/msekhrtk/
Použil som flexbox, ktorý je super no nemá podporu na starších prehliadačoch, tak pozor na to.
Díky za nasměrování na flexbox.
Ještě to ale není úplně ono. Potřeboval bych zachovat bílé pruhy vpravo a vlevo a dále bych potřeboval aby byl prostřední element .content roztažený na celou zbývající výšku. Element bude mít na pozadí obrázek.
Aktualizoval som jsfiddle: https://jsfiddle.net/msekhrtk/ .
Ak ťa dobre chápem, tak teraz by to malo byť ako potrebuješ. V podstate
stačilo pridať esťe jeden wrapper pre hlavičku a obsah. Bez neho by bol
obsah vertikálne vycentrovaný.
Na https://jsfiddle.net/msekhrtk/ je stále tvoje původní verze.
Pokusil jsem se ještě o řešení bez flexboxu.
HTML:
<div class="container">
<div class="header">Hlavicka</div>
<div class="text">Obsah</div>
<div class="footer">Paticka</div>
</div>
CSS:
html, body {
height: 100%;
margin: 0;
}
.container {
height: auto;
margin: 0 auto;
min-height: 100%;
position: relative;
width: 1024px;
}
.header {
background-color: lightgray;
}
.text {
background-color: lightyellow;
padding-bottom: 20px; /* Výška zápatí */
min-height: calc(100vh - 40px); /* Výška 100% - (2 * výška zápatí) */
}
.footer {
background-color: lightgray;
bottom: 0;
height: 20px;
position: absolute;
width: 100%;
}
Calc byl nedávno ještě hodně experimentální věc, jsi si jistý, že dneska už to funguje?
Zlý link, sorry. Aktualizovaná verzia tu: https://jsfiddle.net/msekhrtk/2/
Calc je na tom pododbne ako flexbox, dokonca v niektorých prehliadačoch calc nie je podporovaný vôbec. Taká Opera mini tomu nerozumie, zato flexbox je na tom trochu lepšie a dá sa s ním naozaj vyhrať.
Řešení pro případ, že by odkaz v budoucnu nefungoval:
<!DOCTYPE HTML>
<html>
<head>
<style type="text/css">
body {
margin: 0;
}
.container {
width: 1024px;
margin: 0 auto;
display: flex;
flex-direction: column;
min-height: 100vh;
justify-content: space-between;
background-color: LightYellow;
background-image:
url("http://www.itnetwork.cz/images/5/marketing/man-notes-macbook-computer_resized.jpg");
background-size: cover;
}
.header {
background-color: LightGray;
}
.footer {
background-color: LightGray;
}
</style>
</head>
<body>
<div class="container">
<div>
<div class="header">Hlavicka</div>
<div class="content">Obsah</div>
</div>
<div class="footer">Paticka</div>
</div>
</body>
</html>
Patička nemá fixní velikost. Potřebuji, aby se hlavička i patička roztáhly podle obsahu.
Asi nejhubenější řešení co mě napadá
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title></title>
<style>
html {height: 100%; box-sizing: border-box;}
* {padding: 0px; margin: 0px;}
*, *:before, *:after { box-sizing: inherit;}
body {min-height: 100%; width: 100%; position: relative;}
.header {width: 100%;}
.content {width: 100%; }
.footer {width: 100%; position: absolute; bottom: 0;}
</style>
<body>
<body>
<div class="header">Hlavicka</div>
<div class="content">Obsah</div>
<div class="footer">Paticka</div>
</body>
</html>
Ještě jedna modifikace téhož, ale trochu jinak... patička nějakou velikost mít musí, protože se tam (ostatně i v předchozím používá position: absolute a zbytečně by se to pralo s obsahem, kdyby obsah narazil na patičku)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title></title>
<style>
html { position: relative; min-height: 100%; }
body { margin: 0 0 6em;}
.footer { position: absolute; bottom: 0;}
</style>
<body>
<body>
<div class="header">Hlavicka</div>
<div class="content">Obsah</div>
<div class="footer">Paticka</div>
</body>
</html>
Zobrazeno 16 zpráv z 16.