Parent Container not "maintaining" the same height - html

I have a bizarre CSS bug happening.
I was able to adjust the height of main #app to always be 100% of a given screen size.
This worked through every page of my app but one. I don't know what's possibly causing the conflict as the classes are named identically on every page.
The only difference is that some pages have less content than others. But should this matter? I've tried adding !important but no dice.
I have my:
html, body {
height: 100%;
min-height: 100%;
}
#app {
background: url('someurl') no-repeat fixed;
background-size: contain;
height: 100%;
min-height: 100%;
width: 100%;
margin: 0 auto;
display: inline-block; //this is what fixed in other pages
}
#app .child-container {
float: right;
z-index: 9999;
margin: 30px auto 0 auto;
width: 70%;
}
The bug looks like the example bellow:
Ps: I removed the background image and added a red color just to show how the height of the #app is changing inexplicably.

You could try using the vh unit instead of percentage. 1 vh represents 1% of the viewports,
therefore
html, body {
min-height: 100vh;
}
just min-height should suffice.
Further reading: https://developer.mozilla.org/en-US/docs/Web/CSS/length

If you want an HTML element to fill the screen height ( or width )
you can use 'vh/vw' ( for view height/width) instead of '%' on the body
html, body {
height: 100vh;
}

Related

Why my page in bigger than my window in html? [duplicate]

http://codepen.io/basickarl/pen/Wrwdam?editors=110
html:
<div class="back">
</div>
css:
html,
body {
height: 100%;
}
div.back {
margin-top: 50px;
display: absolute;
width: 30px;
height: 30px;
background-image: url('http://simpleicon.com/wp-content/uploads/arrow-35.png');
background-repeat: no-repeat;
background-position: center;
background-size: contain;
}
The scrollbar on the right displays. I have to have html, body at 100% because of a sticky footer I'm using. Any ideas?
the body element has a default margin: 8px; in most major browsers so first you have to remove that by resetting the margin property on the body element
body {
margin: 0;
}
Then, instead of using height: 100%; on the body use min-height: 100%; so that the body can also grow beyond 100% height when used in conjunction with overflow: hidden;
Since min-height doesn't work if the parent height isn't explicitly set, a height attribute has to be added to the html element as well.
html {
height: 100%;
}
body {
margin: 0;
min-height: 100%;
overflow: hidden;
}
Also, your div.back selector has an invalid value on the display property. the display property accepts inline, inline-block, block, none, flex, inline-flex, grid etc... whereas the position property accepts static (default for every element), absolute, relative or fixed. This is not a problem but rather something the browser just ignores as it doesn't understand it.
div.back {
display: absolute; // <------ remove this line
//... snipped ...
}
It's partially because the default browser style sheets add some margins and/or padding. Resetting them to 0 will fix part of it (JSFiddle).
However you've also got a div with some margins applied (50px). The way the box-model works will mean you'll need to minus that from your 100%. You can use calc if you really need to (or just change it to padding):
height: calc(100% - 50px);
Example using the above code: http://codepen.io/anon/pen/mVPpYK
Example using padding: http://codepen.io/anon/pen/OMNzqB?
If you inspect element, you can see it because of back margin-top style.
Solution
Instead of margin-top, use top.
And then add margin: 0to your HTML/BODY.
There is another thought, even though some of these answers work. Set the body to have a margin of 0 and float the div to the left.
Example - Code Pen
html, body { height: 100%; margin: 0; }
div.back {
float: left;
margin-top: 50px;
width: 30px;
height: 30px;
background-image: url('http://simpleicon.com/wp-content/uploads/arrow-35.png');
background-repeat: no-repeat;
background-position: center;
background-size: contain;
}
You should use overflow.
body {
height: 100%;
overflow:hidden;
}
Try using:
html, body {
height: 100%; overflow: hidden;
}

How to set dimensions of an element to fill only the initial window/viewport size?

I'm trying to make an element maintain only to the initial 100% height of the viewport. So anytime the user resize their windows, the height shouldn't be responsive.
Am i suppose to write javascript to get the initial viewport height and then create those deliver those dimensions to the css? Anybody can show me how to do that?
* {
margin: 0;
padding: 0;
}
.top {
height: 100vh;
width: 100%;
background-color: yellow;
}
.bottom {
height: 300px;
width: 100%;
background-color: red;
}
class top is the div i want to maintain its initial 100% viewport size.
I don't think you need a javascript for that. The height: 100vh; from your code will do just fine.

Background image not working although path is correct

I'm trying to clone a website in my local environment. For some reason, background image doesn't show even though the path is correct as shown in the jpg below.
The photo is in the same folder as index.html and style.css. The css is below:
.wallpaper {
background-image:url('jobbatical-1-wallpaper.jpg');
background-repeat: no-repeat;
background-position: top;
background-size: cover;
height: 100%;
}
.navbar {
overflow: hidden;
background-color: green;
position: fixed;
top: 0;
left: 0;
width: 100%;
z-index: 10;
}
.navbar a {
float: left;
display: block;
color: blue;
text-align: center;
padding: 14px 16px;
text-decoration: none;
}
The problem is that 100% height is useless if the parent has no height.
What do height do you want the image to have? 100% of the viewport or just fill the page?
(100% of the viewport would mean that you have to scroll to see the full picture because of your navbar)
Here is the code of the image should copy the height of the viewport:
(EDIT: maybe you should set the height of the image to 100vh instead of bodys height)
html,
body
{
height: 100%;
margin: 0px;
}
.navbar
{
background-color:green;
height:50px;
}
.image
{
height: 100%;
background-image: linear-gradient(black,gray);
}
<div class="navbar"></div>
<div class="image"></div>
Here is the code if you want to fill the parent (using flex):
body
{
margin: 0px;
}
.viewport
{
height: 100vh;
display: flex;
flex-direction: column;
width: 100%;
}
.navbar
{
background-color: green;
height: 50px;
}
.image
{
background-image: linear-gradient(black,gray);
flex-grow: 1;/*This will make the image to fill the parents space*/
}
<div class="viewport">
<div class="navbar"></div>
<div class="image"></div>
</div>
Your div has no height. You can tell because you can see the position of the paragraph under it.
Since it has no height, there are no pixels to display the background image on.
You need to give it a height.
You have tried giving it height: 100% but a percentage height means height: auto (i.e. the height of the content, of which you have none) when the parent element's height is auto (which the body element is by default).
If you want to make a div take up the remaining vertical space after other elements have been accounted for, look at flexbox for layout. The Holy Grail layout is a fairly extreme example of that.
Space characters aren't allowed in url's.
So you either don't use spaces or encode it when calling it with %20 instead of the space.
I personally use - or _ instead.
Stackoverflow: "href syntax : is it okay to have space in file name"

how to fit the webpage exactly the screen size without scrolling?

I am new to css and I am finding some difficulty in setting my webpage to fit exactly the screen size but it doesn't fit and a scroll bar occurs. I have tried all the ways mentioned here But none of them works. My web page looks more or less like this. When i used
html{
height: 100vh;
}
body{
width: 100%;
height: 100vh;
background-color: #ffffff;
font-family: gothambook;
position: fixed;
top: 0;
bottom: 0;
}
The scroll bar didn't occur but the content went below the screen and was not visible
html {}
body {
height: 95vh;
}
vh stands for View Height and so 97vh is 97% the View/Browser's height.
https://css-tricks.com/fun-viewport-units/
For some reason 100vh makes it scroll a little.
height: 100vh is not good idea to give it full screen.
Try min-height: 100%
You can fix this problem by changing both height and width to 100%. In your code, you have written height as 100vh.
html,
body{
width: 100%;
height: 100vh;
}
after changing them both to 100% you might still be able to scroll but you can fix that by adding this:
overflow: hidden;
In general for fixing this type of problem for any project this setup I think will always work:
html,
body{
width: 100%;
height: 100%;
overflow: hidden;
margin: 0;
}
If you want to completely disable the scroll then you can replace your styles with only this
html {
overflow: hidden;
}
You're almost there. Target both html and body and set both their width and height to 100%.
html,
body {
width: 100%;
height: 100%;
margin: 0;
}
body {
background: red;
}
If body's direct child has top and bottom margin, it is going to make it scroll. So, we need to take that into account.
This works well for me:
body {
height: calc(100vh - 4rem);
}
.content {
max-width: 98.57rem;
margin: 2rem auto;
box-shadow: -1px 0px 6px 0px rgba(0,0,0,0.75);
min-height: 100%;
}
<body>
<div class="content">
....
</div>
</body>

html, body 100% causing scrollbar to appear

http://codepen.io/basickarl/pen/Wrwdam?editors=110
html:
<div class="back">
</div>
css:
html,
body {
height: 100%;
}
div.back {
margin-top: 50px;
display: absolute;
width: 30px;
height: 30px;
background-image: url('http://simpleicon.com/wp-content/uploads/arrow-35.png');
background-repeat: no-repeat;
background-position: center;
background-size: contain;
}
The scrollbar on the right displays. I have to have html, body at 100% because of a sticky footer I'm using. Any ideas?
the body element has a default margin: 8px; in most major browsers so first you have to remove that by resetting the margin property on the body element
body {
margin: 0;
}
Then, instead of using height: 100%; on the body use min-height: 100%; so that the body can also grow beyond 100% height when used in conjunction with overflow: hidden;
Since min-height doesn't work if the parent height isn't explicitly set, a height attribute has to be added to the html element as well.
html {
height: 100%;
}
body {
margin: 0;
min-height: 100%;
overflow: hidden;
}
Also, your div.back selector has an invalid value on the display property. the display property accepts inline, inline-block, block, none, flex, inline-flex, grid etc... whereas the position property accepts static (default for every element), absolute, relative or fixed. This is not a problem but rather something the browser just ignores as it doesn't understand it.
div.back {
display: absolute; // <------ remove this line
//... snipped ...
}
It's partially because the default browser style sheets add some margins and/or padding. Resetting them to 0 will fix part of it (JSFiddle).
However you've also got a div with some margins applied (50px). The way the box-model works will mean you'll need to minus that from your 100%. You can use calc if you really need to (or just change it to padding):
height: calc(100% - 50px);
Example using the above code: http://codepen.io/anon/pen/mVPpYK
Example using padding: http://codepen.io/anon/pen/OMNzqB?
If you inspect element, you can see it because of back margin-top style.
Solution
Instead of margin-top, use top.
And then add margin: 0to your HTML/BODY.
There is another thought, even though some of these answers work. Set the body to have a margin of 0 and float the div to the left.
Example - Code Pen
html, body { height: 100%; margin: 0; }
div.back {
float: left;
margin-top: 50px;
width: 30px;
height: 30px;
background-image: url('http://simpleicon.com/wp-content/uploads/arrow-35.png');
background-repeat: no-repeat;
background-position: center;
background-size: contain;
}
You should use overflow.
body {
height: 100%;
overflow:hidden;
}
Try using:
html, body {
height: 100%; overflow: hidden;
}