/baron

Кроссбраузерная кастомизация системного скроллбара. http://habrahabr.ru/company/2gis/blog/169359/

Primary LanguageJavaScript

Minimalistic (>1.5 kb minified, >0.7 kb gzipped) version of Baron custom scroll without accordeon headers support.

Demo

Features:

  • Does not replace native system scroll mechanic.
  • Customizable scrollbar design with full CSS support.
  • No strong dependences on jQuery.

Baron just hides system scrollbar, but doesn't remove it. This can guarantee scroll work on any system where CSS property 'overflow: scroll' is supported.

##Simple usage

To start using baron.js go throught following steps:

  • Include dev or min version of baron.js:
<script src="baron.js"></script>
  • Make some html:
<div class="wrapper">
    <div class="scroller">
        <div class="container">
        	Your scrollable content here
        </div>
        <div class="scroller__bar"></div>
    </div>
</div>
  • And some CSS:
.wrapper {
    position: relative;
    overflow: hidden;
}
.scroller {
    height: 100%;
    overflow-y: scroll;
}
.scroller::-webkit-scrollbar { /* Preventing webkit bug of horizontal scrolling */
    width: 0;
}
.scroller__bar { /* The bar. You should define width, right and background */
    position: absolute;    
    z-index: 1;
    right: 0;
    width: 10px;
    background: #999;
}
.container { /* Data wrapper */
    overflow: hidden; /* For possible margin collapse removing */
}

Note: you can choose any class names, and slylize them as you want.

  • Initialize baron:
baron($('.wrapper'), {
    scroller: '.scroller',
    container: '.container',
    bar: '.scroller__bar'
});

There can be many wrappers on page, but only first scroller, container and scroller__bar on each wrapper will be initialized. Also, make sure you have either jQuery or custom DOM, events and selector engines.

Demo