Pen Settings

HTML

CSS

CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URLs added here will be added as <link>s in order, and before the CSS in the editor. You can use the CSS from another Pen by using its URL and the proper URL extension.

+ add another resource

JavaScript

Babel includes JSX processing.

Add External Scripts/Pens

Any URL's added here will be added as <script>s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.

+ add another resource

Packages

Add Packages

Search for and use JavaScript packages from npm here. By selecting a package, an import statement will be added to the top of the JavaScript editor for this package.

Behavior

Auto Save

If active, Pens will autosave every 30 seconds after being saved once.

Auto-Updating Preview

If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.

Format on Save

If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.

Editor Settings

Code Indentation

Want to change your Syntax Highlighting theme, Fonts and more?

Visit your global Editor Settings.

HTML

              
                <div class="site-wrap">
      <h1>Slide in on Scroll</h1>

      <p>
        Consectetur adipisicing elit. Tempore tempora rerum, est autem
        cupiditate, corporis a qui libero ipsum delectus quidem dolor at nulla,
        adipisci veniam in reiciendis aut asperiores omnis blanditiis quod quas
        laborum nam! Fuga ad tempora in aspernatur pariaturlores sunt esse
        magni, ut, dignissimos.
      </p>
      <p>
        Lorem ipsum cupiditate, corporis a qui libero ipsum delectus quidem
        dolor at nulla, adipisci veniam in reiciendis aut asperiores omnis
        blanditiis quod quas laborum nam! Fuga ad tempora in aspernatur pariatur
        fugit quibusdam dolores sunt esse magni, ut, dignissimos.
      </p>
      <p>Adipisicing elit. Tempore tempora rerum..</p>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
        tempora rerum, est autem cupiditate, corporis a qui libero ipsum
        delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
        asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
        aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
        dignissimos.
      </p>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
        tempora rerum, est autem cupiditate, corporis a qui libero ipsum
        delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
        asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
        aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
        dignissimos.
      </p>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
        tempora rerum, est autem cupiditate, corporis a qui libero ipsum
        delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
        asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
        aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
        dignissimos.
      </p>

      <img src="http://unsplash.it/400/400" class="align-left slide-in" />

      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Voluptates,
        deserunt facilis et iste corrupti omnis tenetur est. Iste ut est dicta
        dolor itaque adipisci, dolorum minima, veritatis earum provident error
        molestias. Ratione magni illo sint vel velit ut excepturi consectetur
        suscipit, earum modi accusamus voluptatem nostrum, praesentium numquam,
        reiciendis voluptas sit id quisquam. Consequatur in quis reprehenderit
        modi perspiciatis necessitatibus saepe, quidem, suscipit iure natus
        dignissimos ipsam, eligendi deleniti accusantium, rerum quibusdam fugit
        perferendis et optio recusandae sed ratione. Culpa, dolorum
        reprehenderit harum ab voluptas fuga, nisi eligendi natus maiores illum
        quas quos et aperiam aut doloremque optio maxime fugiat doloribus. Eum
        dolorum expedita quam, nesciunt
      </p>

      <img src="http://unsplash.it/400/401" class="align-right slide-in" />

      <p>
        at provident praesentium atque quas rerum optio dignissimos repudiandae
        ullam illum quibusdam. Vel ad error quibusdam, illo ex totam placeat.
        Quos excepturi fuga, molestiae ea quisquam minus, ratione dicta
        consectetur officia omnis, doloribus voluptatibus? Veniam ipsum
        veritatis architecto, provident quas consequatur doloremque quam quidem
        earum expedita, ad delectus voluptatum, omnis praesentium nostrum qui
        aspernatur ea eaque adipisci et cumque ab? Ea voluptatum dolore itaque
        odio. Eius minima distinctio harum, officia ab nihil exercitationem.
        Tempora rem nemo nam temporibus molestias facilis minus ipsam quam
        doloribus consequatur debitis nesciunt tempore officiis aperiam
        quisquam, molestiae voluptates cum, fuga culpa. Distinctio accusamus
        quibusdam, tempore perspiciatis dolorum optio facere consequatur quidem
        ullam beatae architecto, ipsam sequi officiis dignissimos amet impedit
        natus necessitatibus tenetur repellendus dolor rem! Dicta dolorem, iure,
        facilis illo ex nihil ipsa amet officia, optio temporibus eum autem odit
        repellendus nisi. Possimus modi, corrupti error debitis doloribus dicta
        libero earum, sequi porro ut excepturi nostrum ea voluptatem nihil
        culpa? Ullam expedita eligendi obcaecati reiciendis velit provident
        omnis quas qui in corrupti est dolore facere ad hic, animi soluta
        assumenda consequuntur reprehenderit! Voluptate dolor nihil veniam
        laborum voluptas nisi pariatur sed optio accusantium quam consectetur,
        corrupti, sequi et consequuntur, excepturi doloremque. Tempore quis
        velit corporis neque fugit non sequi eaque rem hic. Facere, inventore,
        aspernatur. Accusantium modi atque, asperiores qui nobis soluta cumque
        suscipit excepturi possimus doloremque odit saepe perferendis temporibus
        molestiae nostrum voluptatum quis id sint quidem nesciunt culpa. Rerum
        labore dolor beatae blanditiis praesentium explicabo velit optio esse
        aperiam similique, voluptatem cum, maiores ipsa tempore. Reiciendis sed
        culpa atque inventore, nam ullam enim expedita consectetur id velit
        iusto alias vitae explicabo nemo neque odio reprehenderit soluta sint
        eaque. Aperiam, qui ut tenetur, voluptate doloremque officiis dicta
        quaerat voluptatem rerum natus magni. Eum amet autem dolor ullam.
      </p>

      <img src="http://unsplash.it/200/500" class="align-left slide-in" />

      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
        maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
        Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
        voluptatibus expedita quia vero perferendis, deserunt et incidunt
        eveniet
        <img src="http://unsplash.it/200/200" class="align-right slide-in" />
        temporibus doloremque possimus facilis. Possimus labore, officia dolore!
        Eaque ratione saepe, alias harum laboriosam deserunt laudantium
        blanditiis eum explicabo placeat reiciendis labore iste sint.
        Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
        eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
        consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
        rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
        aliquid laboriosam architecto at cupiditate commodi expedita in, quae
        blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
        culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
        corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
        Laboriosam rem, ratione. Autem blanditiis
      </p>

      <p>
        laborum neque repudiandae quam, cumque, voluptate veritatis itaque,
        placeat veniam ad nisi. Expedita, laborum reprehenderit ratione soluta
        velit natus, odit mollitia. Corporis rerum minima fugiat in nostrum.
        Assumenda natus cupiditate hic quidem ex, quas, amet ipsum esse dolore
        facilis beatae maxime qui inventore, iste? Maiores dignissimos dolore
        culpa debitis voluptatem harum, excepturi enim reiciendis, tempora ab
        ipsam illum aspernatur quasi qui porro saepe iure sunt eligendi tenetur
        quaerat ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati
        officiis quo, ratione eveniet, provident pariatur. Veniam quasi expedita
        distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
        facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
        perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
        distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
        vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
        reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
        odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
        porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
        facere ducimus accusantium eos veritatis neque.
      </p>

      <img src="http://unsplash.it/400/400" class="align-right slide-in" />

      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
        maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
        Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
        voluptatibus expedita quia vero perferendis, deserunt et incidunt
        eveniet temporibus doloremque possimus facilis. Possimus labore, officia
        dolore! Eaque ratione saepe, alias harum laboriosam deserunt laudantium
        blanditiis eum explicabo placeat reiciendis labore iste sint.
        Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
        eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
        consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
        rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
        aliquid laboriosam architecto at cupiditate commodi expedita in, quae
        blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
        culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
        corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
        Laboriosam rem, ratione. Autem blanditiis laborum neque repudiandae
        quam, cumque, voluptate veritatis itaque, placeat veniam ad nisi.
        Expedita, laborum reprehenderit ratione soluta velit natus, odit
        mollitia. Corporis rerum minima fugiat in nostrum. Assumenda natus
        cupiditate hic quidem ex, quas, amet ipsum esse dolore facilis beatae
        maxime qui inventore, iste? Maiores dignissimos dolore culpa debitis
        voluptatem harum, excepturi enim reiciendis, tempora ab ipsam illum
        aspernatur quasi qui porro saepe iure sunt eligendi tenetur quaerat
        ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati officiis
        quo, ratione eveniet, provident pariatur. Veniam quasi expedita
        distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
        facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
        perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
        distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
        vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
        reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
        odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
        porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
        facere ducimus accusantium eos veritatis neque.
      </p>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
        maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
        Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
        voluptatibus expedita quia vero perferendis, deserunt et incidunt
        eveniet temporibus doloremque possimus facilis. Possimus labore, officia
        dolore! Eaque ratione saepe, alias harum laboriosam deserunt laudantium
        blanditiis eum explicabo placeat reiciendis labore iste sint.
        Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
        eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
        consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
        rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
        aliquid laboriosam architecto at cupiditate commodi expedita in, quae
        blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
        culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
        corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
        Laboriosam rem, ratione. Autem blanditiis laborum neque repudiandae
        quam, cumque, voluptate veritatis itaque, placeat veniam ad nisi.
        Expedita, laborum reprehenderit ratione soluta velit natus, odit
        mollitia. Corporis rerum minima fugiat in nostrum. Assumenda natus
        cupiditate hic quidem ex, quas, amet ipsum esse dolore facilis beatae
        maxime qui inventore, iste? Maiores dignissimos dolore culpa debitis
        voluptatem harum, excepturi enim reiciendis, tempora ab ipsam illum
        aspernatur quasi qui porro saepe iure sunt eligendi tenetur quaerat
        ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati officiis
        quo, ratione eveniet, provident pariatur. Veniam quasi expedita
        distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
        facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
        perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
        distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
        vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
        reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
        odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
        porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
        facere ducimus accusantium eos veritatis neque.
      </p>
    </div>
              
            
!

CSS

              
                html {
  box-sizing: border-box;
  background: #ffc600;
  font-family: "helvetica neue";
  font-size: 20px;
  font-weight: 200;
}

body {
  margin: 0;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

h1 {
  margin-top: 0;
}

.site-wrap {
  max-width: 700px;
  margin: 100px auto;
  background: white;
  padding: 40px;
  text-align: justify;
}

.align-left {
  float: left;
  margin-right: 20px;
}

.align-right {
  float: right;
  margin-left: 20px;
}

.slide-in {
  opacity: 0;
  transition: all 0.5s;
}

.align-left.slide-in {
  transform: translateX(-30%) scale(0.95);
}

.align-right.slide-in {
  transform: translateX(30%) scale(0.95);
}

.slide-in.active {
  opacity: 1;
  transform: translateX(0%) scale(1);
}

              
            
!

JS

              
                function debounce(func, wait = 20, immediate = true) {
  var timeout;
  return function() {
    var context = this,
      args = arguments;
    var later = function() {
      timeout = null;
      if (!immediate) func.apply(context, args);
    };
    var callNow = immediate && !timeout;
    clearTimeout(timeout);
    timeout = setTimeout(later, wait);
    if (callNow) func.apply(context, args);
  };
}

const sliderImages = document.querySelectorAll(".slide-in");

function checkSlide(e) {
  sliderImages.forEach(sliderImage => {
    // half way through the image
    const slideInAt =
      window.scrollY + window.innerHeight - sliderImage.height / 2;
    // bottom of the image
    const imageBottom = sliderImage.offsetTop + sliderImage.height;
    const isHalfShown = slideInAt > sliderImage.offsetTop;
    const isNotScrolledPast = window.scrollY < imageBottom;

    if (isHalfShown && isNotScrolledPast) {
      sliderImage.classList.add("active");
    } else {
      sliderImage.classList.remove("active");
    }
  });
}

window.addEventListener("scroll", debounce(checkSlide));

              
            
!
999px

Console