Background-Attachment: Fixed Doesn't Work On iOS

20,000

I just went through the same issue, and this is how I solved it.

First, you need to declare your body and html to be 100% wide and 100% tall:

html, body{
	width: 100%;
	height: 100%;
}

Then, the scrolling on your page can NOT be done by the body: you must wrap it on a container. This container needs three parameters: overflow:scroll, width: 100% and height: 100%. I recommend wrapping the entire site in it:

#wrapper{
		width: 100%;
		height: 100%;
		overflow: scroll;
	}

If you don't like how it scrolls, you can also try adding -webkit-overflow-scrolling: touch.

Hope that helps you/whoever comes looking for this!

Share:
20,000
Jordan U.
Author by

Jordan U.

Updated on June 04, 2022

Comments

  • Jordan U.
    Jordan U. almost 2 years

    I'm trying to find a solution to the problem I'm having with fixed backgrounds on iOS devices. I would rather not have to redesign everything for this website, and I'm hoping that some CSS changes can fix it. This is what the site looks like on iPhones, and this is what it should look like. The CSS code I'm using is as follows:

    .container {
        min-width: 320px;
        max-width: 480px;
        margin: 0 auto;
    }
    
    .fixed-background {
        height: 800px;
        -webkit-backgound-size: cover;
        -o-backgound-size: cover;
        -moz-backgound-size: cover;
        background-size: cover;
        background-attachment: fixed;
        background-repeat: no-repeat;
        background-position: center center;
        text-align: center;
        overflow: auto;
    }
    

    I've also tried using a @media query to fix it for iOS using some posts on stackoverflow, but this didn't seem to have any effect:

    @media screen and (min-color-index:0) and (-webkit-min-device-pixel-ratio:0) {
        .fixed-background {
            background-attachment: scroll;
        }
    } 
    

    HTML

    <div class="fixed-background bg-1">
        <div class="container">
            <div class="title">
                <h1>ROOK PROPERTY<br>MANAGEMENT INC.</h1>
                <h2>CONDOMINIUM MANAGEMENT</h2>
            </div>
        </div>
    </div>
    
  • Stirling
    Stirling about 3 years
    Solution didn't work for me. Also be aware that this solution will potentially create problems with other scrolling effects