Small and quick implementation of a CSS-customizable Scrollbar for use in situations where a div with a fixed height contains content that overflows past its boundaries. This implementation is based off of the scrollbar designs found in various places on Facebook, GMail, and Trello.
- One-line instantiation means you are up and running in no time.
- Mousewheel and click-and-drag support
- All aspects of the scrollbar container and knob are controlled via CSS
- Automatically detects browser resizing and adjusts all positioning and sizing accordingly.
- Automatically adjusts for changes in content
- core/1.4.1: '*'
- more/18.104.22.168: [Slider, Element.Measure, Element.Shortcuts]
How to use
var myScrollable = new Scrollable(element/elements, options);
- element - (element/elements) The element to make scrollable. Can be selected via $ or $$
- options - (object, optional) See below.
- autoHide (truthy: defaults to true) If set to true, hides the scrollbar when the mouse is not over the target element. Otherwise, the scrollbar will stay visible at all times.
- fade (truthy: defaults to true) If set to true, a fade effect will be applied to the showing and hiding of the scrollbar.
- className (string) If set, will change which class is assigned to the scrollable. Useful if you already have a CSS class named "scrollbar", and do not want to conflict
- proportional (boolean: defaults to true) If set to true, sets the height of the scrollbar to be proportional to the height of the target element.
- proportionalMinHeight (number: defaults to 15) Sets a minimum height for the scrollbar when proportional is true. Must be a positive, non-zero, number.
Fired when the height of the target element changes
Given a div element with a fixed height and proper overflow (that is, anything besides "scroll"/"auto"):
var myScrollable = new Scrollable( $('elem-id') );
Given more than one element, by passing in a CSS selector:
var myScrollables = new Scrollable( $$('.class') );
A more complex example (an container with multiple ul elements to add scrollbars to):
var myScrollables = new Scrollable( $('container').getElements('ul') );
Saving the resulting object into the target element using the Element Store:
$('container').store('scrollable', new Scrollable( $('container') ));
Note: Like some other plugins (e.g. More/Tips), Scrollable creates an element into the document body. It is recommended that you call terminate(); once you are finished with it. This is only applicable for pages where content is dynamically loaded and unloaded.
- New feature (thanks to afoeder!) -- Variable height knob
- Recommending use of Element Store in readme
- Merged changes from afoeder into Scrollable (Implementation of Options Class, and replacement of $() with document.id();
- Added new methods scrollBottom(); and scrollTop();, and new event onContentHeightChange
- Fixed issue with broken knob dragging (Issue 14)
- Merged code submitted by zwacky, resolving issues 6 and 8
- Added "force" arguments to showContainer(); and hideContainer(); if the scrollbar needs to be forcibly hidden/shown (i.e. parent element of container is hidden, but the container itself is not)
- Fixed minor bug in the examples section of the readme
- Fixed issue #9 - Scrollable errors out when string is passed in as target
- Fixed issue #10 - Omission of "Sources" line in package.yml
- Fixed issue #5, regarding incorrect positioning in certain circumstances involving instantiation and the page scrollbar
- Fixed bug where scrollbar was visible for a fraction of a second before being hidden/repositioned.
- Fixed issue where scrolling of the page was always blocked by a Scrollable instance, even if the target element has been scrolled to the top/bottom already
- Added "terminate();", which should be called to remove any existing instances of Scrollable
- Updated Scrollable to support target elements like <textarea>
- Added ability to define a custom class in the event "scrollbar" is already taken
I'd like to thank the following contributors for their assistance with debugging, bugfixing, and enhancing Scrollable:
A note on comments here: These comments are moderated. No comments will show up until they are approved. Comments that are not productive (i.e. inflammatory, rude, etc) will not be approved.
Found a bug in this plugin? Please report it this repository's Github Issues.blog comments powered by Disqus