Styled Scroll provides an overlaid vertical scrollbar for overflowing elements, perfect for creating a stylish scrollbar for all browsers or to simply reduce the amount of space the scrollbar occupies. Unlike other scrolling libraries it does not override default scrolling behavior- it only hides the default scrollbar and places its own. This means that it integrates seamlessly with any scroll animator and performs well no matter how complex the scrolled content is.
<div id='parent'>
<div id='content'>
... content ...
</div>
</div>
To allow the content div to be scrollable all you have to do is create a new StyledScroll object:
var styledScroll = new StyledScroll(document.getElementById('content'));
Firefox support requires the scrollable element to have the same width as its parent
var options = { sameClientWidth: true };
var styledScroll = new StyledScroll(document.getElementById('content'), options);
If you are finished with the object and aren't navigating to a different page, make sure to clear it from memory:
styledScroll.destroy();
The scrollbar will automatically update its dimensions and position with any changes to the scrollable region (see options to configure this behavior). However, changing a scrollbar's styling at runtime may require you to inform it that its position or dimensions have changed:
styledScroll.refresh();
When Styled Scroll is applied to an element it adds the 'hide-scrollbar' class. Include the following css in order to properly hide the default scrollbar on webkit based browsers (Chrome and Safari).
.hide-scrollbar::-webkit-scrollbar {
display: none;
}
Styled Scroll objects contain references to two divs that represent the scrollbar. The track is the region that the scrollbar overlays and the thumb is the indicator or handle that can be moved along the track in order to scroll. In order for them to appear you must specify their appearance. The minimal css must specify the position and dimensions of the track and an appearance for the thumb:
.styled-scroll-track {
top: 0;
right: 0;
height: 100%;
width: 12px;
}
.styled-scroll-thumb {
background: darkolivegreen;
}
You can apply any styles that you want to customize the appearance. For example Chrome's overlaid scrollbar can be approximated by:
.styled-scroll-track {
top: 0;
right: 0;
bottom: 0;
width: 10px;
box-sizing: border-box;
}
.styled-scroll-thumb {
background: rgba(0,0,0,0.5);
border:1px solid rgba(0,0,0,0.42);
background-clip: padding-box;
border-radius: .5px;
}
.styled-scroll-thumb:hover {
background: rgba(0,0,0,0.64);
}
Important note: avoid padding on the thumb or margins on either the thumb or track. Use top/right/bottom/left to change their location.
Chrome | Firefox | IE 10+ | IE < 10 | Safari | Opera | Opera Mini | |
---|---|---|---|---|---|---|---|
Desktop | ✔ | ✔* | ✔ | Native | ? | ✔ | N/A |
Mobile | ✔ | ? | ✔ | N/A | Native | ? | ✖ |
* Important: Firefox requires the option sameClientWidth
to be set to true so that the default scrollbar can be hidden underneath the parent element.
Browsers that lack necessary features for customizing the appearance will revert to the native scrollbar. This primarily affects iOS where -webkit-overflow-scrolling is set to touch to enable inertial scrolling, however the resulting overlayed scrollbars cannot be hidden.
Opera Mini cannot work while it lacks support for element overflow.
refresh()
forces an update on the position and size of the track and thumb.destroy()
removes the custom scrollbar from the dom, enables native scrolling, and deletes any allocated memory or events.getScrollElement()
returns the element provided to the constructor.getTrack()
returns the element used to display the track- it is a sibling of getScrollElement().getThumb()
returns the element used to display the thumb- it is a child of getTrack().
Styled Scroll accepts an options parameter for customized behavior. For brevity falsey default values will not be listed.
Boolean. If the target element will always have the same clientWidth or clientHeight as its parent Styled Scroll can apply compatibility and performance enhancements.
sameDimensions: true is just a shortcut to set sameClientWidth and sameClientHeight to true.
An object that defines when the scrollbar will automatically be refreshed in response to an event.
- contentChange: Boolean. Content additions, modifications, and deletions can affect the scroll height. On most platforms this uses a Mutation Observer.
- windowResize: Boolean. The scrollbar will be updated whenever the window is. This is very useful for any element whose dimensions are determined by window size.
- elementResize: Boolean. The scrollable element has changed in width or height. Since dom elements don't natively fire resize events this is implemented by inserting a child iframe with 100% width and height. This can be computationally intensive when rendering a large number of scrollable elements and may cause layout issues but works for elements that resize for reasons other than the browser being resized.
- poll: Number. An interval in milliseconds to constantly send refreshes. This a brute force approach that will guarantee scrollbar accuracy but consumes resources on static elements. Avoid creating a large number of polling objects on the same page. Non-positive numbers will cause refreshes to be requested at 60fps and a boolean true will use a default poll interval.
Default: { contentChange: true, windowResize: true }
Omitted properties will not be used. To handle all refreshes yourself use refreshTriggers: {}
.
Boolean. Creates a standard StyledScroll object but does not replace the native scrollbar with a styled one. This can be useful for using native scrollbars on specific platforms and still offers event callbacks for scrollstart
and scrollend
. This will be set to true if used on an unsupported platform.
Boolean. Uses the native scrollbar if it does not use any layout space. Many mobile platforms implement their own attractive overlaid scrollbars that users are already accustomed to.
Boolean. The track will be removed from the dom when it does not need to be displayed instead of changing that track's visible
css. The same track will be reinserted if the scrollbar should reappear.
StyledScroll triggers scrollstart
and scrollend
events at the appropriate time. Events can be registered and removed using the on(event, function)
and off(event, function)
methods that take a single event name and the function to be executed as parameters. Example usage: scroller.on('scrollstart', function () { console.log('Scrolling started!'); });
.
- User resizable elements via the css
resize
style will use native scrollbars due to a webkit bug that prevents the scrollbar from being placed properly. This primarily affects textaras as their default isresize: both
on Chrome and Firefox.
Styled Scroll is maintained under the Semantic Versioning guidelines.
Copyright (c) 2015 Nick Largen
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.