Scrollport.js — не скучный плагин для анимации скролла. Примитивное зрелище плавного передвижения скролла, которое мы видим на многих сайтах, всего лишь 1 из 4 режимов в этом плагине. Посмотрите демо и возвращайтесь за информацией о подключении и пользовании.
Плагин умеет не только анимировать скролл, но и назначать ссылки, по нажатии на которые, должна начаться анимация.
$.scrollport( target [, options ] );
$.scrollport( target [, container ] [, options ] );
$.scrollport( top, [, options ] );
$.scrollport( top, [, container ] [, options ] );
$.scrollport( top, left, [, options ] );
$.scrollport( top, left, [, container ] [, options ] );
container.scrollport( target [, options ] );
container.scrollport( top [, options ] );
container.scrollport( top, left [, options ] );
-
target
Либо объект джэйквери, либо селектор элемента, к которому будет происходить скролл. -
container
по умолчанию$(window)
Объект джэйквери, внутри которого будет происходить скролл. -
top
Количество пикселей от верхнего краяcontainer
. В указанную точку будет производиться скролл. -
left
Количество пикселей от левого краяcontainer
. В указанную точку будет производиться скролл. -
options
Настройки отвечающие за режим скролла, детали скроллинга и колбэки.
Плагин имеет 4 режима, в зависимости от выбранного режима будут добавляться индивидуальные настройки. Далее перечислены опции, которые могут быть заданы вне зависимости от выбранного режима.
-
mode
по умолчаниюusual
Название режима:usual
,roll
,hard
илиsoft
. -
interrupt_user
по умолчаниюtrue
Если во время работы плагина пользователь совершит принудительный скролл, движение вызванное работой плагина прекратится. -
interrupt_scrollport
по умолчаниюtrue
Если во время работы плагина будет инициировано новое движение, прежнее прекратится. При значенииfalse
вызванное поверх существующего движение выполнено не будет. -
interrupt
Принимает значениеtrue
илиfalse
, устанавливая такое же значение для опцийinterrupt_user
иinterrupt_scrollport
-
container
Джэйквери элемент, внутри которого будет происходить скролл. Как вы видите, задать контейнер можно не только в качестве аргумента к вызову плагина, но и передать опцией настройках. Результат будет тем же. -
delta
по умолчанию{ top: 0, left: 0 }
Значениеtop
определяет сколько пикселей сверху нужно «не доехать» доtarget
. Значениеleft
определяет количество пикселей слева. Если передать в качестве опции число, будет считаться, что вы передаете{ top: ваше_число, left: 0}
. -
on_start
Функция, которая будет вызвана при начале движения. В качестве аргумента в функцию передается API.this
будет содержать в себеcontainer
. -
on_interrupt
Функция, которая будет вызвана при прерывании работы плагина пользовательским скроллом. В качестве аргумента в функцию передается API.this
будет содержать в себеcontainer
. -
on_finish
Функция, которая будет вызвана при успешном завершении скролла. То есть, если работа плагина не была прервана пользователем. В качестве аргумента в функцию передается API.this
будет содержать в себеcontainer
. -
on_stop
Функция, которая будет вызвана в конце работы плагина. Не важно закончилось движение из-за прерывания, или прошло весь назначенный путь. В качестве аргумента в функцию передается API.this
будет содержать в себеcontainer
.
Плавно доставляет к указанному месту, за заданный промежуток времени.
-
duration
по умолчанию700
Время в миллисекундах за которое скролл пройдет расстояние от своего текущего положения до конечного. -
easing
по умолчаниюswing
Доставляет к указанному месту с заданной скоростью.
-
speed
по умолчанию2500
Количество пикселей, которое скролл должен преодолевать за 1 секунду во время движения. -
max_duration
по умолчанию700
Чтобы не ждать слишком долго, если расстояния до цели велико. Можно определить максимальное количество миллисекунд, которые вы готовы ждать. Чтобы отключить ограничения передайте значениеfalse
. -
min_duration
по умолчанию300
Если расстояние слишком короткое, чтобы не было ощущения слишком резкого перемещения, можно указать время, меньше чем за которое, нельзя приближаться к цели. -
easing
по умолчаниюswing
Мгновенно перемещает нас за несколько пикселей до цели, а потом плавно докатывает до места.
-
distance
по умолчанию5
Расстояние в пикселях, которое остается до цели после мгновенного перемещения. -
duration
по умолчанию50
Время, за которое будет пройден оставшийся путь. -
easing
по умолчаниюswing
Плавно начинает движение в сторону цели, поверх контента появляется белый слой, постепенно становящийся не прозрачным. Когда слой станет абсолютно непрозрачным, скролл мгновенно переместится близк к цели. Затем плавно доедет до месте, во время того, как белый слой плавно исчезнет.
Чтобы изменить какие либо CSS параметры, внутри своих стилей задайте нужны свойства элементу с классом scrollport-overlay
.
-
distance_before
по умолчанию200
Расстояние, которое проходит скролл до того, как слой станет непрозрачным. -
distance_after
по умолчанию200
Расстояние, которое проходит скролл после того, как слой начнет пропадать. -
distance
Позволяет задать значение сразу для обоих свойствdistance_before
иdistance_after
. -
duration_before
по умолчанию200
Время за которое скролл проходит расстояние указанное вdistance_before
. -
duration_after
по умолчанию400
Время за которое скролл проходит расстояние указанное вdistance_after
. -
duration
Позволяет задать значение сразу для обоих свойствduration_before
иduration_after
. -
easing_before
по умолчаниюswing
Изинг, с которым скролл проходит расстояние указанное вdistance_before
. -
easing_after
по умолчаниюswing
Изинг, с которым скролл проходит расстояние указанное вdistance_after
. -
waiting
по умолчанию100
Время, в течении которого слой будет оставаться непрозрачным. -
easing
Позволяет задать значение сразу для обоих свойствeasing_before
иeasing_after
. -
speed
Если цель слишком близко, то скролл будет выполнен с использованием модаroll
. В опцииspeed
можно передать скорость с которой скролл доберется до цели.
$.scrollport( options );
При нажатии на созданную ссылку будет инициирована работа плагина. Все ссылки с атрибутом data-scrollport
автоматически будут считаться ссылками скроллпорта. Если не передать ни одно из значений target
, top
или left
, тогда target
автоматически примет значение атрибута data-scrollport
или href
, или data-href
.
link.scrollport_link( [ target ] [, options ] );
link.scrollport_link( [ target ] [, container ] [, options ] );
link.scrollport_link( top, [, options ] );
link.scrollport_link( top, [, container ] [, options ] );
link.scrollport_link( top, left, [, options ] );
link.scrollport_link( top, left, [, container ] [, options ] );
link
Объект джэйквери, который станет ссылкой скроллпорта.
Доступ к API можно получить следующим образом:
// При инициализации работы плагина.
api = $.scrollport( ... );
// API передается в функцию любого колбэка.
$.scrollport( ..., {
on_finish: function( api ) {
...
}
});
-
api.options
Настройки, переданные при инициализации, объединенные с настройками по умолчанию. -
api.status
В момент инициализации статусinit
. Если произошел сбой при инициализации, или инициализация была отменена значение будетcancel
. Во время движенияmotion
. После прерыванияinterrupt
. При успешном завершенииfinish
. -
api.container
Объект джэйквери переданный в качествеcontainer
при инициализации. -
api.target
Если в качестве цели был передан селектор или объект джэйквери,api.target
будет содержать в себе джэйквери элемент. Если целью были координаты, то вapi.target
будет объект вида{ top: ..., left: ... }
// В режиме «usual» переместить скролл наверх страницы.
$.scrollport( 'body' );
// В режиме «soft» переместить скролл за 500 пикселей от верха страницы
$.scrollport( 500, { mode: 'soft' } );
// В режиме «hard» переместить скролл элемента с id «my_container» в точку на 100 пикселей правее начала контейнера, и 40 пикселей ниже.
$( '#my_container' ).scrollport( 100, 100, {
mode: 'hard'
delta: 60
} );
// В режиме «usual» переместить скролл к элементу страницы с id «my_element». В конце движения вывести статус скроллпорта в консоль.
$.scrollport( '#my_element', {
on_stop: function( api ) {
console.log( api.status );
}
} );
Можете взять через bower:
$ bower install scrollport-js
Можете через npm:
$ npm install scrollport-js
Даже на cdn есть. Ссылка на последнюю версию. Если нужна будет какая-то другая версия, измените «1.0.4» в ссылке на нужное значение:
https://cdn.rawgit.com/iserdmi/scrollport-js/1.0.4/dist/scrollport.min.js
И только в крайнем случае скачивайте напрямую.
Тогда помогите, пожалуйста, перевести документацию на английский язык. Переведите часть текста и отправьте комментарием к этому топику.