Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yoshuawuyts/virtual-widget
Create a virtual-dom widget
https://github.com/yoshuawuyts/virtual-widget
Last synced: 2 months ago
JSON representation
Create a virtual-dom widget
- Host: GitHub
- URL: https://github.com/yoshuawuyts/virtual-widget
- Owner: yoshuawuyts
- License: mit
- Created: 2015-10-04T13:29:17.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2016-03-12T05:16:04.000Z (almost 9 years ago)
- Last Synced: 2024-10-10T14:58:47.271Z (3 months ago)
- Language: JavaScript
- Size: 8.79 KB
- Stars: 22
- Watchers: 3
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-virtual-dom - virtual-widget - dom widget (Modules / Widgets)
README
# virtual-widget
[![NPM version][npm-image]][npm-url]
[![build status][travis-image]][travis-url]
[![Test coverage][codecov-image]][codecov-url]
[![Downloads][downloads-image]][downloads-url]
[![js-standard-style][standard-image]][standard-url]Create a virtual-dom widget.
## Installation
```sh
$ npm install virtual-widget
```## Usage
```js
// map.js
const virtualWidget = require('virtual-widget')module.exports = virtualWidget({
init: function (state) {
this.state = state
var elem = document.createElement('div')
this.map = GoogleMap(elem)
this.map.setPosition(this.state.position)
return elem
},
update: function (prev, el) {
this.map = this.map || prev.map
this.map.setPosition(this.state.position)
},
destroy: function (el) {
// clear position
this.state.position.set({ x: 0, y: 0 })
}
})
```
```js
// view.js
const map = require('./map')module.exports = view
function view (h, state) {
return h('section.foo', [
map(state)
])
}
```## API
### render = virtualWidget(hooks)
Create a new `virtual-widget` using hooks. The following hooks are available:
- __init__: run when the element is first created. Define the instantiation
logic here.
- __update__: run on a re-render. Gives a chance to update state.
- __destroy__: run before the widget is unmounted. It is passed the HTMLElement
associated with the widget that will be removed. Generally used to clean up
data and remove hooks.
- __render__: return a string of HTML for server side rendering. It's
recommended to use [vdom-to-html][1] for server-side rendering.## See Also
- [virtual-dom/docs/widgets](https://github.com/Raynos/mercury/blob/master/docs/widgets.md)
- [mercury/docs/how-to-do-custom-rendering](https://github.com/Raynos/mercury/blob/master/docs/faq.md#how-do-i-do-custom-rendering)
- [vdom-to-html][1]## License
[MIT](https://tldrlegal.com/license/mit-license)[npm-image]: https://img.shields.io/npm/v/virtual-widget.svg?style=flat-square
[npm-url]: https://npmjs.org/package/virtual-widget
[travis-image]: https://img.shields.io/travis/yoshuawuyts/virtual-widget/master.svg?style=flat-square
[travis-url]: https://travis-ci.org/yoshuawuyts/virtual-widget
[codecov-image]: https://img.shields.io/codecov/c/github/yoshuawuyts/virtual-widget/master.svg?style=flat-square
[codecov-url]: https://codecov.io/github/yoshuawuyts/virtual-widget
[downloads-image]: http://img.shields.io/npm/dm/virtual-widget.svg?style=flat-square
[downloads-url]: https://npmjs.org/package/virtual-widget
[standard-image]: https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat-square
[standard-url]: https://github.com/feross/standard
[1]: https://github.com/nthtran/vdom-to-html