How to keep Bootstrap Carousel paused until it enters the viewport

Thanks for the information. Your time and effort is appreciated. I’m off to give this a try and will post back to let you know how I get on.

Hello, Paul. Following your advice I’ve added the code from your most recent Codepen to position my rounded image in the header of my page but it doesn’t appear in the same position as it does in your Codepen. It’s lower down on the right-hand side instead of tighter up in the right-hand corner. Take a look https//cleardirectionhypnotherapy.co.uk

I think the HTML in your latest Codepen is different from my actual page because the Codepen HTML is the old version before you added the olay-container.

Here is the original HTML before you added the olay-container

  <!-- Header -->
  <header class="bg-primary py-5 mb-5 my-header">
    <div class="container h-100">
      <div class="row h-100 align-items-center">
        <div class="col-lg-12">
          <div class="image-wrap image-wrap2">
            <img class="round" src="https://picsum.photos/id/1000/200/200" width="200" height="200" alt="round Pic">
          </div>
          <h1 class="display-4 text-white mt-5 mb-2">Lorem ipsum dolor sit amet Lorem ipsum dolor sit amet Lorem ipsum dolor sit amet </h1>
          <h2>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod</h2>
          <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.</p>
          <div class="img-credit">Lorem ipsum dolor sit amet</div>
        </div>
      </div>
    </div>
  </header>

and here is my current HTML

<header class="bg-primary py-5 mb-5 my-header"> 
<div class="olay-container container">
<div class="row align-items-center">
<div class="col-lg-12"> 

<div class="image-wrap image-wrap2">
            <img class="round" src="https://picsum.photos/id/1000/200/200" width="200" height="200" alt="round Pic">
          </div>

<h1 class="display-4 text-white mb-2">Lorem ipsum dolor</h1>
<h2>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod</h2>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.</p>
<div class="img-credit">Lorem ipsum dolor sit amet</div>
</div>
</div>
</div>
</header> 

Please can you tell me whether I’ve inserted the HTML for the rounded image in the correct place in my existing code and whether it’s possible for us to position the image closer to the top right-hand corner of the header text area, and which styling controls this?

I’ve included all of this CSS in my stylesheet.

Is this all necessary and correct or have I duplicated some?

.image-wrap {
  width: 100px;
  aspect-ratio: 1 /1;
  margin: 1rem;
  position:absolute;
  right:8px;
  top:20px;
}
.image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid red;
  box-shadow: 0 0 5px 5px rgba(0, 0, 0, 0.5);
}
.r2 {
  width: 20%;
}
.r3 {
  width: 9%;
}



.sidebar .image-wrap,
.image-wrap2 {
  width: 100px;
  aspect-ratio: 1 /1;
  position: static;
  margin: 0;
}
.image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid red;
  box-shadow: 0 0 5px 5px rgba(0, 0, 0, 0.5);
}
.sidebar {
  display: flex;
  flex-direction: column;
}
.sidebar:after {
  content: "";
  flex: 1 0 0;
  background: red;
  width: 1px;
  margin: 1rem auto 1rem;
}

header .image-wrap2 {
  position: static;
  float: right;
  margin: 2.5rem 0 0 1rem;
}

@media screen and (max-width: 992px) {
  .sidebar .image-wrap,
  header .image-wrap {
    width: 60px;
  }
}

Progression has been made with my contact form. The form is up on a simple test page here: https://cleardirectionhypnotherapy.co.uk/recaptcha/index.html.

I need to alter the form around, remove the Bootstrapious text and position it properly, but it does work and sends messages successfully.

My question is, in your opinion, is it best to embed the form into my actual contact page so it follows the same style as the rest of my site, or to keep it on a page of its own with a plain background?

I’ve already tried to embed it into my actual page but ran into all kinds of problems outlined below.

After reading through, is there a simple way for me to get this embedded and working, or should I just stick with a link to a separate form?

My website runs on Bootstrap 4.3.1 and jquery 3.4.1

The contact form runs on Bootstrap 4.0.0 and jquery 3.2.1

I’ve copied and pasted the HTML for the contact form into my own contact page, together with links to dependencies.

I am pretty sure I shouldn’t ever be running more than one version of Bootstrap on the same page, or jquery for that matter, but for the purposes of experimentation I left them unaltered to begin with and the contact form appears to display exactly as is intended.

Further experimentation reveals that I can comment out the link to Bootstrap 4.0.0 engine, and also to jquery 3.2.1 without any noticeable effects, but perhaps this may affect the form’s ability to be able to send messages.

However, with both Bootstrap CSS versions 4.3.1 for my website and 4.0.0 for the contact form running together at the same time my page nav turns blue instead of white.

I commented out the link to Bootstrap 4.0.0 CSS for the contact form and my page nav returns back to its intended colour, but then the contact form firstname, lastname, email, and phone fields reposition themselves so as not to align properly with the lower message field.

Here is a link to the contact form running both version 4.3.1 and 4.0.0 Bootstrap CSS at the same time you’ll notice that the form displays properly but my page nav is the wrong colour.
https://cleardirectionhypnotherapy.co.uk/contact.html

Here is a link to the contact form running just version 4.3.1 for my website with the correct colour page nav but the misaligned form fields.

https://cleardirectionhypnotherapy.co.uk/contact2.html

Just reduce the top margin here:

header .image-wrap2 {
    position: static;
    float: right;
    margin: 2.5rem 0 0 1rem;
}

Change the 2.5rem to zero (or whatever you want).

I would hazard a guess that the contact form will work with the newer versions ok so I would test with the current version of bootstrap and jquery. You can’t mix them on the same page anyway and you don’t want to force your users to download new versions of both on a different page as that defeats the point of them being cached on first page load.

As far as the look goes then it seems that apart from the odd margin it will look the same.

You would of course need to test function as you can’t do that from my codepen.

Very Importantly I nothe that in your custom css you have this rule.

.row {
    display: flex;
    margin: 0 0 0 2px;
}

You must never directly change the bootstrap grid rules as that breaks all pages. The row class is an integral part of bootstrap and used everywhere and by all third parties. It has default -15px left and right margins which are integral to the design as they match the 15px padding on the container and on the col classes. All three …container,.row and ,col work together to for the bootstrap grid. Changing anyone breaks the other two unless you change each in the same way,

I suggest you go back and read how the grid works again so you don’t make that mistake again. :slight_smile:

As I mentioned before if you really need to over-ride one of the bootstrap rules you should add your own class and then use that class to modify the bootstrap rules. Never change any of the bootstrap classes themselves or you risk breaking all other pages and any third party code also.

Thanks for the info. Following your advice, I’ll make the alterations you suggest to the CSS for my rounded image. I’ll also test the contact form with the most recent versions of Bootstrap and jquery.

As I mentioned yesterday, when running my form with the latest versions of Bootstrap and jquery, and when looking at https://cleardirectionhypnotherapy.co.uk/contact2.html the alignment of the forms fields is not quite the same as when using the versions of Bootstrap and jquery that came with the form. Does this matter, and is there a way for me to make all fields of my form align and appear equal in terms of left and right-hand margins as in https://cleardirectionhypnotherapy.co.uk/contact.html.

The part about row margins having been altered from their Bootstrap default, I must have done this but I can’t remember when or why.

Again, following your advice, is it then correct for me to change

.row {
    display: flex;
    margin: 0 0 0 2px;
}

back to

.row {
    display: flex;
    margin: -15px 0 0 -15px;
}

Is this correct?

Most of my previous post was addressing that point lol :slight_smile:

The alignment is out because you changed the value of the margins on .row ;). Look at my example as I reinstated the bootstrap margins.

No :slight_smile:
You changed the top and left margins not the left and right margins.

Anyway all you need to do is remove the margin rule you added and let the original rule in the bootstrap css take over.

You should then create a new class for the element that you only wanted a 2px margin and use that for that element as required.

Once again, thank you. I’ll make the changes and report back to let you know how I get on. Enjoy your evening :slight_smile:

1 Like

Hello Paul. Apologies for the long delay in my reporting back. I hope you are doing okay.

I’d like to ask another question and am happy to post it in the appropriate section of the forums if you’d prefer, but thought it worth asking you first.

Running Page Speed on my index test page is giving me a first contentful paint speed of 2.8 for mobile with the largest contentful paint element being my header block with its image of a beach and sea. I’ve experimented and optimized this image further to around 240kb but with a noticeable loss of quality and only very minimal improvement in speed, and based upon the loss of image quality I reverted back to the existing image.

I was wondering whether improvement could be made by either swapping out my main header image for a progressive loading image only I’m not sure whether this should be jpg or png and the best method to use to save my image as interlaced.

Also, serving a smaller version of the same image for mobile, how to alter my existing stylesheet by adding what I guess would be conditional comments to specify a smaller version image for smaller screens, and what size I should save a smaller image.

There are other improvements I can make by asynchronously loading JS and minimising CSS, etc. but wanted to focus on the header issue first of all.

Any advice would be appreciated.

https://tobias.is/blogging/even-faster-images-using-http2-and-progressive-jpegs/

Meant to add this which I found while Googling. Would any of these techniques help to speed up FCP?

You could just add a media query at say about max-width 800px and then specify the new smaller image in that media query. (Similar to how you change anything else in the media queries.) The only draw back to that is people like me who continually open and close their browser window and I will get 2 images loaded if they cross the breakpoint. Its not really a problem because most people don’t do that and on mobile you only have the one window size anyway.

There are many image optimising tools around the web and they can perform much better than your standard paint packages so its worth having a google for those.

The webp image format seems to offer best compression format and is now widely supported.

Image optimisation isn’t really my area so you may be better off starting a new thread if the above doesn’t help. :slight_smile:

.

Hi Paul, and thanks for your reply.

Would it be possible for you to get me started by giving me an example of how to alter my existing styling to make this happen? https://cleardirectionhypnotherapy.co.uk

Here is the relevant section:

.my-header {
  background-image: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.1) 0%,
      rgba(0, 0, 0, 0.1) 100%
    ),
    url("../img/miscellaneous/huttoft/optimized/webp/289KB/1200758.webp");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
}

After some Googling I’ve read that it’s possible to speed up FCP by using ‘image-set()’ https://developer.mozilla.org/en-US/docs/Web/CSS/image/image-set and, as you have already pointed out, making a smaller or set of smaller images available for different-sized screens and letting the browser choose which one is most appropriate depending on the device being used.

Having never tried this I’m not entirely sure how to include this into my existing code without breaking it.

How many images should I make available, in what dimensions, and what file names?

How can I test to be certain the browser is choosing the most appropriate image depending on the device being used?

I’ve read that making my image progressive is more likely to improve performance than interlaced and I’ve found this online converter.

https://coding.tools/progressive-jpeg

Any advice appreciated.

Oh, forgot to include that following Google’s advice I’ve saved all of my images as WEBP, having first run them through TinyJPG, but I’m guessing that to use a progressive image this will need to be a JPG?

I was wondering whether altering my existing code to something like this (based on what I’ve been reading in the Mozilla article) would be on the right track. although I don’t think I need the .avif, just 2 or more versions of the same image saved as .jpg or .webp but in differing sizes.

.my-header {
  background-image: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.1) 0%,
      rgba(0, 0, 0, 0.1) 100%
    ),
    url("../img/miscellaneous/huttoft/optimized/webp/289KB/1200758.webp");
    background-image: image-set(
    "large-balloons.avif" type("image/avif"),
    "large-balloons.jpg" type("image/jpeg")
  );
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
}

You would just duplicate that .my-header section but place it in a max-width media query making sure to change the image name to your new image.

I’m on a mobile at the moment so not easy to cut and paste code :slight_smile:

I was going to mention image-set but I think that’s probably overkill for your use case. I also have doubts that you may end up serving higher quality images to mobile devices because mobile screens are much more dense than desktops. In effect the opposite of what you wanted. I haven’t done enough testing on it to make my mind up.

I’m still of the opinion that simpler is better. A simple media query and swapping for a smaller image for small screens is an easier option and allows for art direction in that the smaller image can be different to the large image.

Thanks, Paul.

Following your suggestions and knowing very little about media queries or how to write them, I’ve been reading this guide https://developer.mozilla.org/en-US/docs/Learn/CSS/CSS_layout/Media_queries

and if my understanding is correct I’d write something like

@media media-type and (media-feature-rule) {
  /* CSS rules go here */
}

then adjust as appropriate and add my styling

@media screen and (max-width: 800px) {
 
.my-header {
  background-image: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.1) 0%,
      rgba(0, 0, 0, 0.1) 100%
    ),
    url("../img/miscellaneous/huttoft/optimized/webp/smaller-image.webp");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
}

}

My actual stylesheet should end up looking like the following example, with my original code block followed by my new media query code block.

.my-header {
  background-image: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.1) 0%,
      rgba(0, 0, 0, 0.1) 100%
    ),
    url("../img/miscellaneous/huttoft/optimized/webp/image.webp");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
}

@media screen and (max-width: 800px) {
 
.my-header {
  background-image: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.1) 0%,
      rgba(0, 0, 0, 0.1) 100%
    ),
    url("../img/miscellaneous/huttoft/optimized/webp/smaller-image.webp");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
}

}

Is this correct?

Is it worth me repeating this same media query block again for max-width 480, max-width 1200, and max-width 1920, each with an appropriately sized image?

When sizing my images, should I save them at exactly 480, 800, 1200, and 1920px widths?

I’ve saved my existing images as WEBP but as the header image is the largest in file size would making this a progressive JPG improve page loading speed and FCP?

Yes that looks correct but more importantly did you test it and see if it worked? :slight_smile:

I would advise against that approach because a user may change a device from landscape to portrait (and vice versa) and you then hit them with another download resulting in greater overhead than if you had loaded the larger image to start with.

Although most people don’t close their browser windows too small on a desktop they will still tweak the widths to fit other applications and once again you force them to download multiple images instead of one.

I rarely find I need more than one image apart from the hero. I create an image for a medium size screen and then allow it to stretch and shrink as required. With careful optimisation and good selection of image you can nearly always satisfy most cases with one image.

Simpler is better but always crush the image size with a dedicated image crusher. Very rarely will I use anything over 300k.

Also remember that a mobile width may be 375px or thereabouts and if you create an image at 375 px then it will look bad on double density as most devices are these days (or more). The image would need to be double the 375px width and then scaled smaller in css.

Lastly you should really be editing images from their original source files and not just cropping a copied image

Thanks, Paul.

Thanks for all of the information. The points you make are duly noted.

Testing this was my next question because I’m not sure how to test whether the smaller image is being used when appropriate. How do I check?

I have the original bitmap image which is roughly 5.10mb and so can crop and optimize from this.

As previously, what sizes should I aim to save the larger and smaller images as, and would the progressive jpg be an option to speed up downloading?

For testing you could use two different images of different things and it will be obvious. However its easier to use developer tools and look at the image that is being used in the css panel.

If you are using two images then I would expect that your smaller image would be a more appropriate section of the scene anyway rather than just squeezing the whole large image down smaller.

That would be trial and error process and seeing what is the best compromise for you. For the large screen image I would look at something around 1500px - 1800px wide that can be stretched in css 2500px for large screens without looking to bad and can scale down to 1000px also. I would rarely just choose the largest image size and scale down.

For smaller screens you could then have an image about 700px wide that can scale all the way down to zero and up to the 1000px mark… Its really trial and error and compromise.

Unfortunately I see background images mainly as a distraction and I will use a lower quality image than most people as its not that important to me as long as it looks ok.

I don’t really like images that start as low quality and then get better as they download. I’d rather wait for the real image. But then again that’s just me :slight_smile:

Once again, thank you, Paul.

That’s more than enough for me to be getting on with and it all makes sense, so I’ll go and have an experiment and will report back when I’ve got a bit further.

Until then, all good wishes, H.

1 Like

Hello, Paul.

As promised, here’s an update on how I’ve been getting on with the changes we recently discussed.

As far as the main header image is concerned, I’ve taken my original image, cropped it down in size, and saved it in two sizes, larger for desktop and smaller for mobile. I then optimized them using TinyJPG.

My larger image is coming in at 299 KB, and the smaller one is at 120 KB.

The smaller image is saved as a progressive jpg and also as a standard jpg.

I’m currently pointing to the progressive jpg.

I’ve added the media query to my CSS so the smaller image loads on smaller screens and tested this by right-clicking on the image both in large and small screen sizes, opening in a new tab, saving to my desktop, opening in Photoshop and checking dimensions. The media query is working as intended.

I’ve run Pagespeed against my page and it’s returning a first contentful paint speed for desktop of 0.8 and for mobile 2.0

Here are the screenshots for each test

https://cleardirectionhypnotherapy.co.uk/24.07.23/desktop.png

https://cleardirectionhypnotherapy.co.uk/24.07.23/mobile.png

The Pagespeed checker is reporting bootstrap.min.css and bootstrap.js as causing a delay in FCP.

It suggests asyncing or deferring these to speed up FCP but I think this will cause my page to behave unpredictably while loading. Is this true?

The checker is also reporting Google as delaying loading, and I’m guessing this is the search bar script. This script is being called in on page load, so I’m guessing we can’t async or defer this.

I have experimented with cropping my smaller image down more and also reducing its quality and its resulting file size but this doesn’t seem to have had very much impact on FCP speed so I’ve left it as it is for now.

Perhaps worth mentioning is that my server is based in a USA data centre and the hosts say that I might achieve higher speeds if I were to pay more by moving to the UK data centre instead.

In your opinion, should I continue to try to improve FCP speed for mobile and which (if any) of the above would you focus on when trying to do this?

Moving on to other matters.

The other issue I have is with my cookie bar.

As you can see from the cookie bar HTML below, there are a couple of inline styles that centre the text and also the accept button.

I’d like to move this inline styling to my cookie bar external stylesheet, but try as I may I have been unable to work out how to do this without breaking the centering of its text and button.

Please would you take a look and if possible provide an example of how I would alter the cookie bar external CSS to include the two inline styles so these can then be removed from my HTML page?

<!-- Cookiealert Bar -->
<div class="alert alert-dismissible text-center cookiealert" role="alert">
<div class="cookiealert-container">
<div class="cookies" style="margin-left:55px;"><b>Do you like cookies?</b> &#x1F36A; This website uses cookies to improve your experience.&nbsp;&nbsp;</div><a href="https://cookiesandyou.com/" target="_blank">More</a>&nbsp;&nbsp;<button type="button" class="btn btn-primary btn-sm acceptcookies" aria-label="Close" style="margin:4px;">I agree</button>
</div>
</div> 
/*
 * Bootstrap Cookie Alert by Wruczek
 * https://github.com/Wruczek/Bootstrap-Cookie-Alert
 * Released under MIT license
 */
.cookiealert {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    margin: 0 !important;
    z-index: 999;
    opacity: 0;
    border-radius: 0;
    transform: translateY(100%);
    transition: all 500ms ease-out;
    color: #ecf0f1;
    background: #212327 url('');
}

.cookiealert.show {
    opacity: 1;
    transform: translateY(0%);
    transition-delay: 1000ms;
}

.cookiealert a {
    text-decoration: underline;
}

.cookiealert .acceptcookies {
    margin-left: 50px;
    vertical-align: baseline;
}

/* cookiealert container height */
.cookiealert-container .cookies{
	margin:5px;
}

Any help and advice would be appreciated. :slight_smile: