Skip to content

Latest commit

 

History

History
123 lines (90 loc) · 3.58 KB

README.md

File metadata and controls

123 lines (90 loc) · 3.58 KB

Replace.js

Tool for adding simple AJAX functionality to a site. See the demo for example use cases.

Background

After doing web development for a while, we noticed that most interactions we added to the site involved catching a click event, performing an AJAX request, and updating part of the page based on the result. This typically required a lot of boilerplate JavaScript to set up click handlers. All that JavaScript slowed down the initial page load, and until the page finished loading, things didn't work right. It also required duplicating business and rendering logic on the server and the client. The site was slow and our JS code was brittle and difficult to test. We realized that one small library could implement this pattern and replace most of our JS code base.

We weren't the first to reach a similar conclusion -- see Makinde Adeagbo's excellent presentation on Primer.

Requirements

Any server-side language should do, though we use Rails. jQuery must be present.

Installation

Put the contents of primer.min.js in a <script> tag in the document header. Link to replace.js at the bottom of the document body, below jQuery.

<script src="/path/to/replace.js"></script>

Usage

You AJAX-ify a link by giving it a data-replace attribute containing a jQuery selector. When the link is clicked, its closest ancestor matching the selector will be replaced by the result of an AJAX request to the link's href.

<div class="container">
  <a href="/foo" data-replace=".container">Foo</a>
</div>

The link can replace itself. A convenient selector for doing so is '*'.

<a href="/foo" data-replace="*">Foo</a>

It is up to you to ensure that the server returns an appropriate partial in response to that AJAX request. If the URL also represents a full page that might be visited normally (e.g. linked externally), add the data-pushstate attribute to have the window's location updated using the history.pushState() API. The server can check the X-Requested-With header to determine whether to return a partial or a full page.

<a href="/foo" data-replace="*" data-pushstate>Foo</a>

The data-replace attribute also works on forms, catching the submit event.

<form action="/foo" data-replace="*">
  <input type="submit">
</form>

Styling

While the AJAX operation is in progress, the matched container will have the CSS class .replace-active. Clicks/submits within that container will be ignored until the current operation completes, so you don't have to worry about forms being submitted twice when a user double-clicks the button.

The .replace-active class can be useful for styling the container in order to give the user feedback about when the operation begins and ends. For instance, the following CSS style will cause elements to be faded when they are in the process of being replaced:

.replace-active {
  opacity: 0.5;
}

Events

When a replace operation occurs, a replace:done event is triggered on each top-level element of the inserted partial. For example, given the following listener:

$(document).on('replace:done', 'p', function() {
  console.log(this.innerHTML);
});

If the server returns the following partial:

<p>First.</p>
<p><em>Second.</em></p>
<div><p>Third.</p></div>

The console will print:

First.
<em>Second.</em>

License

This project is released under the MIT license.