-
Notifications
You must be signed in to change notification settings - Fork 495
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
offcanvas isn't scrollable #421
Comments
I'm also having this issue and not able to solve it. all the solutions found in github and stackovrflow don't work. most point to having to refer to the last version to sort this out. |
I found this only happens on smaller phone sizes (not iphone 6 for example). I believe it can be fixed by adding data-placement="left" (for a navmenu-fixed-left), at least with this it works in all my test devices. Edit: This does not fix the issue. |
This workaround does not work for me. I checked your website, and it doesnt work there either. I was able to get scrolling to work once when its first opened by hacking the css and a small javascript event. But the second time its opened scrolling is frozen again. 😞 |
Completely agree, checked it myself and it is not working. Sorry for this, but I did have it scrolling for sure. Must have been something in addition to the data-placement, digging trough my commits right now to find it. Edited my previous answer to reflect this as not_working. |
ok, I got it (kind of) working again. You also have to set data-disableScrolling="false" AND use the not-minified js file. This might be a completely different issue, but take a look at the comments at a freshly downloaded js: the minified version says 3.1.0, while the not-minified version says 3.1.3. Anyways now the menu does scroll, the only downside is that the body also scrolls. But that is not a big issue for me. The relevant part is line 159 of the not-minified js, this seems to break scrolling not only on the body but on all other elements as well. @kfirba @mgwidmann Please let me know if this works for you as well. |
@rhein Hey. I've added that code to my button:
And I'm also using the sass version and concatenate some css files with gulp. It still doesn't work. I've dug into the code and found that if I set the If I also manually call
It works. The downside now is that EVERYTHING is scrolling. The body and the nav-menu which is annoying. I've tried to play with it to only get the side-menu scrolling but I couldn't. |
@kfirba Yes, this is pretty much what I did. The downside is ok for me, as at least on iOS devices body and nav-menu are scrolling independently, so it is not too much of an annoyance and the menu is actually usable. Just as a sidenote:
in order to prevent the scrolling, but that does not work. I guess we have to live with this for now until somebody comes up with a clever idea on how to prevent scrolling on touch devices. |
@rhein I see. When adding the properties on the button it didn't work so I had to invoke a JS function manually. |
Yes, looks like setting the properties via data-attributes does not work. So, to sum it up for others:
The important part here is disableScrolling: false, Alternative Call
right after invoking the nav-menu. This should re-enable scrolling for both the nav-menu and the body. The Downside: it might be annoying to have the body scrolling as well. @kfirba Do you think this sums it up correctly? |
@rhein Unfortunately, yup. :) |
Yeah, disable scrolling works as in it allows the side menu to scroll. However, the body being scrollable was not acceptable for us. We had to roll back the version to get things to work again, through a combination of that and some css hacks things are working for us. This definitely needs to work out of the box though or this component is useless. |
@mgwidmann Do you mind sharing your solution? |
@mgwidmann I would be great if you could share your solution or even send in a pull request. Thanks! |
I can't share the codebase, but I can show you the relevant code that got this to work for me. Hopefully you can find a better solution because mine involves setting some CSS which is kind of hacky. SCSS:
And we add that class with
|
@mgwidmann thank you, it helped
|
I have experienced the same issue. The way I "solved" it, is using this: |
This seems to be working for me:
On the show.bs.offcanvas event, I am stopping scrolling on the entire body EXCEPT for elements that are children of an element with the "offcanvas" class. Then I remove it when the canvas is hidden to re-enable normal scrolling. Lastly, I set the body to overflow: hidden to fix an issue where the page would scroll if the slider was scrolled all the way to the very top or bottom, then scrolled again in the same direction. This is allowing the content of the panel to scroll while not scrolling the rest of the page. |
For those interested, I made a PR to fix the issue of |
This is what worked for me. The 3.1.2 version worked for me for iOS but had problem with desktop browsers and I would get locked scrolling after opening and closing the side menu. So I replaced this line in jasny-bootstrap.js with the version from 3.1.3 . I kept the CSS with the 3.1.2 version. This is important because the changes in the CSS cause this to not work in iOS.
Now scrolling works fine for iOS and Desktop browsers for me. |
offcanvas sets the style of body to overflow : hidden, that is why it is not scrollable, you can simply use document.body.style.overflow = "auto" on click on the button using which you are opening the offcanvas. |
Hey.
For some reason the offcanvas isn't scrollable on phones. I tried both iPhones and androids (LG and samsung) and the offcanvas, once exceeded the 100% height isn't scrollable for some reason.
You can see more details in the SO question:
http://stackoverflow.com/questions/33787983/jasny-bootstrap-offcanvas-doesnt-scroll-on-phones
The text was updated successfully, but these errors were encountered: