6

I have a responsive site where I'm using a javascript to create a sticky sidebar.

I'm also using media queries to change from a multi-column layout to a single-column layout when the browser size is less than 768px.

I need to figure out how to disable the sticky menu script in the single-column layout. Essentially, I need something like a media query for the script statement.

This is the code I'm using to enable the script:

<script>
jQuery('#info').containedStickyScroll({
        duration: 0,
        unstick: false
    });
</script>

Is there something I can add to it to only have it trigger if the window is 768px wide or wider?

EDIT: I'm looking for a solution that will work if the user resizes the window on the fly.

1

3 Answers 3

7

Try this.

$(function(){
     $(window).resize(function(){
         if($(this).width() >= 768){
             jQuery('#info').containedStickyScroll({
                 duration: 0,
                 unstick: false
             });
         }
      })
      .resize();//trigger resize on page load
});
Sign up to request clarification or add additional context in comments.

5 Comments

@MДΓΓ БДLL This works based on the window size at page load; is there a way to make it work if the user resizes the page after it is loaded?
@MДΓΓБДLL - I thought OP needs only when the width should be 768 but yest >= should be better.
IME it's best to debounce the resize handler since this event can be fired a lot while the window is resized. I like this jQuery plugin: benalman.com/code/projects/jquery-throttle-debounce/examples/…
@ShankarSangoli Thanks. The updated code works if the window starts small and is enlarged beyond 768, but not if the window starts large and is reduced below 768.
If the window width is reduced below 768 then the if condition will fail and it will not do anything. If you want to do something else in this case then have a else block and write the required code.
0

Try this code:

var height = $(window).height(); //I'm assuming you mean height, you can try .width() if yo u need it

if (height < 768) {
  jQuery('#info').containedStickyScroll({
      duration: 0,
      unstick: false
  });
}

Hope that helps.

Comments

0

Check this out:

var targetWidth = 768;
if ( $(window).width() &gt;= targetWidth) {     
  //Add your javascript for screens wider than or equal to 768 here
  jQuery('#info').containedStickyScroll({
      duration: 0,
      unstick: false
  });
}
else {
  //Add your javascript for screens smaller than 768 here
  console.log(`am less than ${targetWidth}`)
}

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.