Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/josephernest/swap

Swap.js is a "HTML-over-the-wire" AJAX-navigation micro-library
https://github.com/josephernest/swap

ajax dom fetch-api html javascript single-page-applications vanilla-js xmlhttprequest

Last synced: 11 days ago
JSON representation

Swap.js is a "HTML-over-the-wire" AJAX-navigation micro-library

Awesome Lists containing this project

README

        

# Swap.js

![logo_new300px](https://github.com/josephernest/Swap/assets/6168083/38f392b7-b537-4cb9-a52a-6c0ef25a8c85)

**Swap.js** is a JavaScript micro-library which facilitates AJAX-style navigation in web pages, in less than ~ 100 lines of code. (See ["Why?"](#user-content-why-a-100-line-of-code-limit) paragraph below)

This is inspired by the recent libraries that make server-side-rendering and "HTML-over-the-wire" techniques popular again (HTMX, Unpoly, Hotwire...).
In short, portions of a web page can be replaced by new content sent directly from the server as HTML fragments, in a very simple way.

Demo here using this library: [**Demo**](https://afewthingz.com/swap-library/email/)

Features:

* AJAX-style navigation and replacement of HTML elements of the page
* handling of the browser history (history back button, etc.)
* automatic code launcher when HTML elements are created/removed in the DOM
* adapted for single page applications (or not)

Important aspects:

* vanilla JS (no external tool needed: no bundler, no webpack, no TypeScript compiler, no minification needed...)
* the good old ` ```
>
Click me
>

Container
`
> ```
>
> When you click on *"Click me"*, the element `#container` is replaced by `newpage.html`'s `#container`. Simple isn't it?

# Simple example

See `demo1/` folder.

`index.html`
```

Home
Go to screen 2

Container

```

`screen2.html`
```

Home
Go to screen 2

You are on screen 2!

```

Of course, in real life, you don't want to duplicate the same header and footer in multiple HTML files, and you will want to use server-side rendering: for a more complete example, see `demo2/` folder with PHP code, multiple screens, multiple containers to be replaced, and also with some JS code that is run automatically when elements are inserted/destroyed in the DOM.

# More advanced example

The folder `demo3-email/` is another example of usage of the library. Nearly no JS is written, but mostly HTML attributes.

[**Live demo**](https://afewthingz.com/swap-library/email/)

[![](https://user-images.githubusercontent.com/6168083/183262644-de8b396c-a0ee-46fc-9ebc-943ba7bf656b.png)](https://afewthingz.com/swap-library/email/)

# Documentation

You can use these 3 features:

* **`swap-target` (HTML attribute)**

If present on a `` based on the history URL.
If you want to update something else than `` when going back in history, you can set the HTML attribute `swap-history-restore` on the element which will be restored.

* **Loader/unloader JS functions when DOM elements are added/removed**

Sometimes, you want to execute JS code when a new HTML fragment is inserted, or when it is removed. Here is how it works:

```
Swap.loaders['.screen2'] = () => {
console.log("An element with class screen2 has just been inserted in the DOM.")
var task = setInterval(() => { console.log("On repeat!"); }, 1000);
return () => { clearInterval(task); }; // in a loader function, you return an unloader function which will be executed when the element is removed from DOM
}
```

# Why a 100 line-of-code limit?

When you start a new web project and decide to use a rather new library xyz.js, you always take the risk that:

* eventually xyz.js will not be maintained anymore
* a feature is missing but you don't know where to add it in the 50 different source code files with a total of 10'000 lines of code
* there is a strange bug but you can't find where it is in these 10k lines of code
* the library has hundreds of features you don't need

For this reason, this micro-library will always stay single-file and not have more than ~ 100 lines of code. No complex feature will be added, it will stay very basic. The benefit of all this is that you can read, understand, and improve the full code of the micro-library in less than 1 hour of your time.

This project's source code was initially *much larger* than its current state, with more complex mechanisms (for the same result), and I spent good time simplifying it and keep (what I find) the most elegant solution. It looks simple now, but it wasn't initially ;) (the use of MutationObserver API was helpful).

# Contributions

Issues, ideas, discussions are welcome - please open an issue before doing a pull request to be sure it is necessary.

Which simple feature would you want to to see included? After all the current code is < 50 lines of code, so there is plenty of room until reaching the 100 lines of code limit :)

# Author

Joseph Ernest

For R&D, Python, data science, automation consulting/freelancing requests, please contact me on https://afewthingz.com.

Sponsors are welcome to support the development of my open-source projects.

I am currently sponsored by [CodeSigningStore.com](https://codesigningstore.com). Thank you to them for providing a DigiCert Code Signing Certificate and supporting open source software.

# License

MIT