1.0.2 • Published 8 years ago

dom-scroller v1.0.2

Weekly downloads
1
License
MIT
Repository
github
Last release
8 years ago

dom-scroller

Install

npm install --save dom-scroller

Usage

The javascript is inline, but you might be using something like browserify. If so just think of the javascript as external.

<!DOCTYPE html>
<html>
<head>
    <title>Dom list test</title>
    <style>
    #list-container{
        background-color: green;
        cursor: default;
        /*The important styles are overflow, and height.*/
        overflow-y: auto;
        height: 100px;
        padding: 10px;
    }
    #list{
        padding: 10px;
        margin: 10px;
    }
    #container2{
        background-color: red;
        cursor: default;
        /*The important styles are overflow, and width.*/
        overflow-x: auto;
        width: 250px;
        padding: 20px;
        white-space: nowrap;
    }
    #hlist{
        padding: 10px;
        margin: 10px;

    }
    #hlist li{
        display: inline;
    }

    </style>
    </head>
<body>
    <button id="up1">up</button>
    <button id="down1">down</button>
    <div id="list-container">
        <ol id="list" type="1">
            <li>zero</li>
            <li>one</li>
            <li>two</li>
            <li>three</li>
            <li>four</li>
            <li>five</li>
            <li>six</li>
            <li>seven</li>
            <li>eight</li>
            <li>nine</li>
            <li>ten</li>
            <li>eleven</li>
            <li>twelve</li>
            <li>thirteen</li>
            <li>fourteen</li>
            <li>fifteen</li>
        </ol>
    </div>
    <button id="right">Scroll Right</button>
    <div id="container2">
        <ol id="hlist">
            <li>zero</li>
            <li>one</li>
            <li>two</li>
            <li>three</li>
            <li>four</li>
            <li>five</li>
            <li>six</li>
            <li>seven</li>
            <li>eight</li>
            <li>nine</li>
            <li>ten</li>
            <li>11</li>
            <li>12</li>
            <li>13</li>
            <li>14</li>
            <li>15</li>
        </ol>
    </div>

    <script>
    var createScroller = require('dom-scroller');


    var scroller = createScroller(document.querySelector('#list-container'), {
        edges: 'same'
    });

    document.querySelector('#down1').addEventListener('click', function(e){
        scroller.jumpTo(document.querySelector('#list').children[11]);
    }, false);

    document.querySelector('#up1').addEventListener('click', function(e){
        scroller.jumpTo(document.querySelector('#list').children[3]);
    }, false);

    var scroller2 = createScroller(document.querySelector('#container2'), {
        edges: 'split'
    });

    document.querySelector('#right').addEventListener('click', function(){
        scroller2.jumpTo(document.querySelector('#hlist').children[9]);
    }, false);
    </script>
</body>
</html>

The Scroller API

createScroller(element, options) -> instance

Give an element that you want to scroll to the scroller.

options.edges = String

The edges option gives you the ability to control where to scroll when calling the jumpTo method.

If edges is set to split if the child is below the containing element then it will scroll to just above the bottom of the containing element.

If edges is set to same then children will always scroll to the top of the container element.

The default for edges is split.

options.direction = String

direction should be vertical, horizontal, or both. The default is both.

You can constrain the scrolling direction with this option.

options.duration

The default duration for a scroll when you call any of the scrolling methods on the scroller instance.

options.easing = Function

Set an easing function. The default is linear.

Scroller Static Methods

createScroller.Easing

Access to easing functions.

These functions are the same as found in tween.js.

Look at the documentation for tween.js to learn more.

Scroller Methods

The duration parameter for all methods is optional.

tween() -> tween

This creates a tween. The tween object returned is the same as a tween.js object.

tweenScroll(side, distance, duration) -> tween

Tween the scrollbar of the element.

side should be a string equal to Left, or Top. This corresponds to scrollTop, and scrollLeft.

distance should be a negative, or positive integer representing how many pixels you want to scroll.

duration is the duration in milliseconds for the tween to take place.

scrollV(distance, duration) -> tween

Start a vertical scroll automatically.

The same as tweenScroll, but without a side argument.

scrollH(distance, duration) -> tween

Start a horizontal scroll automatically.

The same as tweenScroll, but without a side argument.

jumpTo(element, duration) -> tween

Make the container element scroll to an child element's position.

jumpTo is dependent on the edges option of the constructor.

Scroller Properties

scrollTop = Integer

The same as element.scrollTop.

scrollLeft = Integer

The same as element.scrollLeft.

scrollingV = Boolean

Is the element in the act of scrolling vertically?

scrollingH = Boolean

Is the element in the act of scrolling horizontally?

There are other properties, but for the most part you should ignore those.

1.0.2

8 years ago

1.0.1

8 years ago

1.0.0

8 years ago