Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/google/incremental-dom
An in-place DOM diffing library
https://github.com/google/incremental-dom
Last synced: about 2 months ago
JSON representation
An in-place DOM diffing library
- Host: GitHub
- URL: https://github.com/google/incremental-dom
- Owner: google
- License: apache-2.0
- Created: 2015-06-11T20:15:03.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-06-19T05:44:46.000Z (3 months ago)
- Last Synced: 2024-07-30T12:13:49.797Z (about 2 months ago)
- Language: TypeScript
- Homepage: http://google.github.io/incremental-dom/
- Size: 1.88 MB
- Stars: 3,533
- Watchers: 85
- Forks: 178
- Open Issues: 63
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
- awesome-list - incremental-dom - place DOM diffing library | google | 3392 | (TypeScript)
- awesome - google/incremental-dom - An in-place DOM diffing library (TypeScript)
README
[![CircleCI](https://circleci.com/gh/google/incremental-dom.svg?style=svg)](https://circleci.com/gh/google/incremental-dom)
# Incremental DOM
## Overview
Incremental DOM is a library for building up DOM trees and updating them in-place when data changes. It differs from the established virtual DOM approach in that no intermediate tree is created (the existing tree is mutated in-place). This approach significantly reduces memory allocation and GC thrashing for incremental updates to the DOM tree therefore increasing performance significantly in some cases.
Incremental DOM is primarily intended as a compilation target for templating languages. It could be used to implement a higher level API for human consumption. The API was carefully designed to minimize heap allocations and where unavoidable ensure that as many objects as possible can be de-allocated by incremental GC. One unique feature of its API is that it separates opening and closing of tags so that it is suitable as a compilation target for templating languages that allow (temporarily) unbalanced HTML in templates (e.g. tags that are opened and closed in separate templates) and arbitrary logic for creating HTML attributes.
*Think of it as ASM.dom.*## Supported Browsers
Incremental DOM supports IE9 and above.
## Usage
HTML is expressed in Incremental DOM using the `elementOpen`, `elementClose`, `elementVoid` and `text` methods. Consider the following example:
```javascript
var IncrementalDOM = require('incremental-dom'),
elementOpen = IncrementalDOM.elementOpen,
elementClose = IncrementalDOM.elementClose,
elementVoid = IncrementalDOM.elementVoid,
text = IncrementalDOM.text;function render(data) {
elementVoid('input', '', [ 'type', 'text' ]);
elementOpen('div', '', null);
if (data.someCondition) {
text(data.text);
}
elementClose('div');
}
```To render or update an existing DOM node, the patch function is used:
```javascript
var patch = require('incremental-dom').patch;var data = {
text: 'Hello World!',
someCondition: true
};patch(myElement, function() {
render(data);
});data.text = 'Hello World!';
patch(myElement, function() {
render(data);
});
```## Templating Languages and Libraries
[Check out](ECOSYSTEM.md) what others having been doing with Incremental DOM.
## Docs
- [Introducing Incremental Dom](https://medium.com/google-developers/introducing-incremental-dom-e98f79ce2c5f)
- [Docs and demos](http://google.github.io/incremental-dom/)## Getting Incremental DOM
### Via CDN
https://ajax.googleapis.com/ajax/libs/incrementaldom/0.5.1/incremental-dom.js
https://ajax.googleapis.com/ajax/libs/incrementaldom/0.5.1/incremental-dom-min.js### Using npm
```sh
npm install incremental-dom
```## Development
To install the required development packages, run the following command:
```sh
npm i
```### Running tests
To run once:
```sh
./node_modules/.bin/bazelisk test ...
```To run on change:
```sh
./node_modules/.bin/ibazel run //test:unit_tests
```### Building
To build once:
```sh
./node_modules/.bin/bazelisk build ...
```To build on change:
```sh
./node_modules/.bin/ibazel build ...
```