jquery-stickit

A jQuery plugin provides a sticky header, sidebar or else when scrolling.

  • 所有者: emn178/jquery-stickit
  • 平台:
  • 許可證: MIT License
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

jQuery-stickit

A jQuery plugin provides a sticky header, sidebar or else when scrolling.

Demo

Sidebar
Header
Navbar
Stack Pages
Sticky Columns

Download

Compress
Uncompress

Installation

You can also install jquery-stickit by using Bower.

bower install jquery-stickit

Usage

$('#you-want-stick').stickit(options);

Options

scope: StickScope (default: StickScope.Parent)

Sets the element stick in the parent element or entire document.

StickScope.Parent: Sets the element stick in the parent element.

StickScope.Document: Sets the element stick in the entire document.

className: string (default: 'stick')

Sets the class name to the element when it's stick.

top: number (default: 0)

Sets sticky top, eg. it will be stuck at position top 50 if you set 50.

zIndex: number (default: 100 or z-index of element css)

Sets z-index. Default is try to get element z-index property from css style. If undefined, default is 100.

extraHeight: number (default: 0)

Sets extra height for parent element, it could be used only StickScope.Parent. When the contents of parent has margin or something let the actual height out of container, you could use this options to fix.

screenMinWidth: number (default: undefined)

Sets min width for RWD. This is equal to min-width in media query.

screenMaxWidth: number (default: undefined)

Sets max width for RWD. This is equal to max-width in media query.

overflowScrolling: boolean (default: true)

Sets true to enable scrolling sticky element when its height is higher than the screen.

onStick: function (default: undefined)

Callback event when the element becomes stuck. Or stickit:stick event.

onUnstick: function (default: undefined)

Callback event when the element becomes unstuck. Or stickit:unstick event.

onEnd: function (default: undefined)

Callback event when the element arrives at the end of container. Or stickit:end event.

onUnend: function (default: undefined)

Callback event when the element leaves from the end of container. Or stickit:unend event.

Methods

destroy()

Removes the stickit functionality completely.

refresh()

Refresh the position of stickit element manually.

$.stickit.refresh()

Refresh the position of all stickit elements manually.

Example

// use default settings
$('.stickit').stickit();

// or assign settings
$('.stickit').stickit({top: 43});

// callback events
$('.stickit').stickit({
  onStick: function () {
    // do something
  }
});
// equal to
$('.stickit').stickit().bind('stickit:stick', function () {
  // do something
});

// call pre-defined methods
$('.stickit').stickit('destroy');
$('.stickit').stickit('refresh');

// refresh all
$.stickit.refresh();

Responsive

You can set up multiple options with different min-width and max-width.

$('.stickit').stickit({
  screenMinWidth: 1024    // apply if width >= 1024
}, {
  screenMinWidth: 768,    // apply if width >= 768 && width <= 1023
  screenMaxWidth: 1023,
  top: 10
}, {
  screenMaxWidth: 767,    // apply if width <= 767
  top: 20
});
// array is also fine, equal to
$('.stickit').stickit([{
  screenMinWidth: 1024    // apply if width >= 1024
}, {
  screenMinWidth: 768,    // apply if width >= 768 && width <= 1023
  screenMaxWidth: 1023,
  top: 10
}, {
  screenMaxWidth: 767,    // apply if width <= 767
  top: 20
}]);

If multiple settings match, it will merge and overwrite the setting like css. Eg.

$('.stickit').stickit({
  top: 10,                 // always match
  extraHeight: 10
}, {
  screenMaxWidth: 767,     // apply if width <= 767
  top: 20,
  zIndex: 10
});
// In this case, the settings will be following if width > 767
{
  top: 10,
  extraHeight: 10
}
// the settings will be following if width <= 767
{
  top: 20,
  extraHeight: 10,
  zIndex: 10
}

License

The project is released under the MIT license.

Contact

The project's website is located at https://github.com/emn178/jquery-stickit
Author: Chen, Yi-Cyuan (emn178@gmail.com)

主要指標

概覽
名稱與所有者emn178/jquery-stickit
主編程語言JavaScript
編程語言JavaScript (語言數: 3)
平台
許可證MIT License
所有者活动
創建於2014-01-06 09:09:25
推送於2017-08-21 08:55:14
最后一次提交2017-08-21 16:54:38
發布數20
最新版本名稱v0.2.14 (發布於 2017-08-21 16:54:50)
第一版名稱v0.1.10 (發布於 2015-01-02 14:14:40)
用户参与
星數75
關注者數7
派生數20
提交數66
已啟用問題?
問題數26
打開的問題數2
拉請求數4
打開的拉請求數1
關閉的拉請求數1
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?