Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/johansatge/elastic-columns

✨ A jQuery plugin designed to be used as an alternative to the well-known Isotope library.
https://github.com/johansatge/elastic-columns

elastic-columns grid javascript jquery jquery-plugin

Last synced: 2 months ago
JSON representation

✨ A jQuery plugin designed to be used as an alternative to the well-known Isotope library.

Awesome Lists containing this project

README

        

![Bower](https://img.shields.io/bower/v/elastic-columns.svg)

![Elastic Columns](logo.png)

A jQuery plugin designed to be used as an alternative to the well-known [Isotope](http://isotope.metafizzy.co) library - [View demo](http://johansatge.github.io/elastic-columns/).

> 💡 **Update August 2023:** this project is 9 years old 🎉 it still works, but you might also consider more modern alternatives such as [CSS Grids](https://developer.mozilla.org/en-US/docs/Learn/CSS/CSS_layout/Grids), depending on your use case.

---

* [Why](#why)
* [Installation](#installation)
* [Basic usage](#basic-usage)
* [API](#api)
* [Refreshing the layout](#refreshing-the-layout)
* [Modifying settings on the fly](#modifying-settings-on-the-fly)
* [Destroying the layout](#destroying-the-layout)
* [Ignoring items](#ignoring-items)
* [Changelog](#changelog)
* [License](#license)

## Why

I wanted to make a simple alternative to [Isotope](http://isotope.metafizzy.co) or [Masonry](http://masonry.desandro.com) - those modules work very well, but can be oversized on some cases.

Elastic Columns is lightweight (less than *3kb*) and will suit your needs if you have to build a grid of items using columns with equal widths.

## Installation

With Bower:

```bash
bower install elastic-columns
```

Alternatively, checkout the project and install the minified script whenever you want in your project.

## Basic usage

This code will set the position of the children nodes in your container.

```javascript
var $container = $('.container');
$container.elasticColumns(
{
columns: 3, // the number of colums
innerMargin: 10, // the gap between two tiles
outerMargin: 20 // the gap between the tiles and
// the edge of the container
});
```

This inits the grid once, and then does nothing.

If your container is fluid (i.e. its width can change), you have to set the right number of columns by yourself, like in the example below:

```javascript
$(window).on('resize', function(evt)
{
// Here, we want 4 columns if the size of the window is greater than 800px, 3 columns otherwise
var columns = $container.width() > 800 ? 4 : 3;
$container.elasticColumns('set', 'columns', columns);
$container.elasticColumns('refresh');
});
```

## API

### Refreshing the layout

You may want to refresh the layout when the user resizes the window, or when you add new items to the grid (by appending nodes to your container).

```javascript
$('.container').elasticColumns('refresh');
```

*If you append pictures, be sure to wait for them to be loaded before refreshing the layout, or the calculations may be false.*

### Modifying settings on the fly

You can change the plugin settings at any time.

```javascript
$('.container').elasticColumns('set', 'columns', 4);
$('.container').elasticColumns('set', 'innerMargin', 5);
$('.container').elasticColumns('set', 'outerMargin', 10);
```

*When you are updating a parameter, don't forget to refresh the grid.*

### Destroying the layout

You can restore the layout to its initial state.

```javascript
$('.container').elasticColumns('destroy');
```

### Ignoring items

You may add the `elastic-columns-ignore` class to some items if you don't want them to be positioned on the grid.
This can be useful if you are filtering the grid content and don't want to remove items on the fly.

```html


```

## Changelog

| Version | Date | Notes |
| --- | --- | --- |
| `0.2.1` | August 17th, 2015 | Adds logo and new demo page |
| `0.2.0` | August 17th, 2015 | Adds demo files in the main branch |
| `0.1.1` | July 26th, 2014 | Adds a method to remove the styles set by the plugin. |
| `0.1` | January 29th, 2014 | Initial version |

## License

This project is released under the [MIT License](LICENSE).