Cache Nanocomponents.
var Component = require('choo/component')
var html = require('choo/html')
module.exports = class Article extends Component {
static id (article) {
return `article-${article.id}`
}
createElement (article) {
return html`
<article>
<h2>${article.title}</h2>
<p>${article.body}</p>
</article>
`
}
update () {
return false
}
}
var myComponent = require('./my-component')
var Nanocache = require('nanocomponentcache')
var cache = new Nanocache()
cache(myComponent)
// => create a new instance of myComponent
cache(myComponent)
// => return cached instance of myComponent
Create a new Nanocache instance.
Render a Nanocomponent instance. It checks a static id
method that
returns an id. If the id is not registered in the cache, it creates a new
instance and caches it. If the id already exists, it returns the cached
instance.
Remove all components from the cache that don't currently have a DOM node attached.
$ npm install nanocomponentcache