Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tdumitrescu/virtual-jade
Compile Jade templates to Hyperscript for Virtual DOM libraries
https://github.com/tdumitrescu/virtual-jade
hyperscript jade pug snabbdom virtual-dom
Last synced: 13 days ago
JSON representation
Compile Jade templates to Hyperscript for Virtual DOM libraries
- Host: GitHub
- URL: https://github.com/tdumitrescu/virtual-jade
- Owner: tdumitrescu
- License: other
- Created: 2015-04-05T21:57:13.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2024-07-12T21:29:51.000Z (7 months ago)
- Last Synced: 2025-01-10T11:18:42.068Z (16 days ago)
- Topics: hyperscript, jade, pug, snabbdom, virtual-dom
- Language: JavaScript
- Homepage:
- Size: 812 KB
- Stars: 31
- Watchers: 7
- Forks: 4
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# virtual-jade
[![NPM version][npm-image]][npm-url]
[![Build status][travis-image]][travis-url]
[![Test coverage][coveralls-image]][coveralls-url]Compile your [jade](https://github.com/jadejs/jade) templates into Virtual DOM functions. Works with multiple Virtual DOM libraries, including:
- [virtual-dom](https://github.com/Matt-Esch/virtual-dom)
- [snabbdom](https://github.com/snabbdom/snabbdom)
- [maquette](https://github.com/AFASSoftware/maquette)For people who like declarative reactive templating, but don't like writing HTML or JSX.
Create a template:
```jade
.items
each item in items
.item(
class={active: item.active}
data-id=item.id
)
.item-title= item.title
.item-description= item.description
````require()` your template as a function
and use a rendering system like [main-loop](https://github.com/Raynos/main-loop):```js
const mainLoop = require('main-loop');const template = require('./items.jade');
const initState = {
items: [],
};const loop = mainLoop(initState, template, {
create: require("virtual-dom/create-element"),
diff: require("virtual-dom/diff"),
patch: require("virtual-dom/patch"),
});
document.body.appendChild(loop.target);
```Then update whenever you'd like!
```js
loop.update({
items: [
{
id: 'asdf',
title: 'some title',
description: 'some description',
active: false,
},
],
});
```## Notes
- For easy configuration with Webpack, use [virtual-jade-loader](https://github.com/tdumitrescu/virtual-jade-loader).
- To translate with Babel, use [babel-plugin-virtual-jade](https://github.com/jbwyme/babel-plugin-virtual-jade).
- Can be used with any CommonJS environment with client-side `require()`s.
- All templates must return a single root element.
- Requires you to install the appropriate virtual-dom library in your top-level app.## API
### fnStr = render(str, options)
`str` is the jade source as a string.
`fnStr` is output JS that you should include as a CommonJS module.Options are:
- `filename`: path and name of Jade source file for `str`.
Required if you use `include` or `extends` in templates.
- `marshalDataset=true`: whether to convert `data-` attributes
to `dataset` members. Set to false to treat as props with the same
name as the attributes (if your target Virtual DOM renderer does
not support the `dataset` API).
- `pretty=false`: whether to beautify the resulting JS.
Requires you to install `js-beautify` yourself.
- `propsWrapper`: optional object to wrap Jade attributes in; for example, with `propsWrapper = 'props'`, the template `div(foo="bar")` will translate to something like `h('div', {props: {foo: 'bar'}})` rather than `h('div', {foo: 'bar'})`
- `rawProps`: whether to skip Jade attribute -> HTML property conversion; this is set to true in the default Snabbdom configuration
- `serializeAttrsObjects`: special behavior for the Snabbdom-style `attrs` attribute object. If true, object values within an `attrs` attribute will be automatically stringified (since HTML element attributes are always strings); for example, in `div(attrs={foo: {hello: 'world'}})` the `foo` attr will end up in HTML as `"{"hello":"world"}"` (rather than `"[object Object]"`).
- `runtime`: optional override to include any arbitrary Virtual DOM library that defines the `h()` hyperscript function. E.g. `var h = require('my-special-lib/h');`
- `vdom`: name of the Virtual DOM library configuration to load (currently either `virtual-dom` or `snabbdom`).Returns a string that looks like:
```js
function render(locals) {
var result_of_with = /* stuff */
if (result_of_with) return result_of_with.value;;
}
```You are expected to `eval()` the string if you want the source as a function.
Otherwise, just create a module in the following format:```js
const js = `module.exports = ${fnStr}`;
```Within code blocks in your template code, you can access Jade mixin functions via the `$mixins` variable.
In virtual-jade, mixins boil down to functions that take arguments and return a tree of `h(name, attrs, children)`.
They are like [React stateless components](https://reactjs.org/docs/components-and-props.html).
Accessing them via `$mixins` is useful for special cases where you want to pass around handles to blocks of Jade code as callback functions (see example below).```jade
mixin item(x)
.item
.more-tree= x + 1list-virtual-scroll(props={itemRenderer: $mixins.item})
``````jade
// in list-virtual-scroll.jade
each val in allItems.slice(startIdx, endIdx)
= props.itemRenderer(val)
```## Development notes
- Install deps: `npm install`
- Run tests: `npm test`
- Run linter: `npm run lint`
- Generate coverage report: `npm run test-cov`
- Run all the verifications together: `npm run test-ci`
- Run tests with verbose debugging output (compiled functions as well as rendered HTML): `DEBUG=test npm test`[travis-image]: https://img.shields.io/travis/tdumitrescu/virtual-jade/master.svg?style=flat-square
[travis-url]: https://travis-ci.org/tdumitrescu/virtual-jade
[coveralls-image]: https://img.shields.io/coveralls/tdumitrescu/virtual-jade.svg?style=flat-square
[coveralls-url]: https://coveralls.io/r/tdumitrescu/virtual-jade
[npm-image]: https://img.shields.io/npm/v/virtual-jade.svg
[npm-url]: https://www.npmjs.com/package/virtual-jade