lazyload_rails

lazyload_rails project integrates jQuery Lazy Load Plugin for Rails image_tag helpers


Keywords
jquery, lazyload, rails
License
MIT
Install
gem install lazyload_rails -v 0.1.2

Documentation

Lazyload-Rails

This project integrates the jQuery Lazy Load Plugin for Rails image_tag helpers

What's jQuery Lazy Load?

From the project page:

Lazy Load is a jQuery plugin written in JavaScript. It delays loading of images in long web pages. Images outside of viewport (visible part of web page) won't be loaded before user scrolls to them. This is opposite of image preloading.

Using Lazy Load on long web pages containing many large images makes the page load faster. Browser will be in ready state after loading visible images. In some cases it can also help to reduce server load.

See example (scroll down to see images load)

Documentation

Features

  • Add lazy: true option to Rails image_tag helpers to render lazyload-friendly img tags.
  • Simple (really). That's pretty much it.

Example

<%= image_tag "logo.png", alt: "Logo", lazy: true %>

Equals:

<img alt="Logo" data-src="/images/logo.png" src="http://appelsiini.net/projects/lazyload/img/grey.gif">

Install

Add this line to your application's Gemfile:

gem "lazyload-rails"

Download the jQuery Lazy Load Plugin into your vendor/assets/javascripts directory and include it however you prefer.

And in your JavaScript code do:

$("img").lazyload();

Lazy Load can be customized, see more options

Important: Remember that the Lazy Load Plugin depends on jQuery.

Configuration

By default, a 1x1 grey gif is used as placeholder (from http://appelsiini.net/projects/lazyload/img/grey.gif). This can be easily customized:

# config/initializers/lazyload.rb
LazyloadRails.configure do |config|
  config.placeholder = "/public/img/grey.gif"
end

License

Lazyload-Rails is released under the MIT License.