Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/insin/msx
JSX for Mithril.js 0.x
https://github.com/insin/msx
deprecated jsx mithril unmaintained
Last synced: 4 days ago
JSON representation
JSX for Mithril.js 0.x
- Host: GitHub
- URL: https://github.com/insin/msx
- Owner: insin
- License: other
- Archived: true
- Created: 2014-03-21T00:19:36.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2017-01-30T17:02:42.000Z (almost 8 years ago)
- Last Synced: 2024-12-31T08:47:38.052Z (26 days ago)
- Topics: deprecated, jsx, mithril, unmaintained
- Language: JavaScript
- Homepage:
- Size: 185 KB
- Stars: 361
- Watchers: 17
- Forks: 23
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGES.md
- License: LICENSE
Awesome Lists containing this project
- awesome-react-cn - msx - React's JSX Transformer, tweaked to output calls to Mithril (Uncategorized / Uncategorized)
- awesome-react - msx - React's JSX Transformer, tweaked to output calls to Mithril
- awesome-learning-resources - msx - React's JSX Transformer, tweaked to output calls to Mithril (Uncategorized / Uncategorized)
- awesome-react - msx - JSX for Mithril.js 0.x (React [🔝](#readme))
README
# DEPRECATED
As of Mithril.js v1.0.0, you can use the `react-transform-jsx` Babel plugin for JSX.
See [Mithril.js' JSX documentation](http://mithril.js.org/jsx.html) for details.
---
# MSX [![Build Status](https://secure.travis-ci.org/insin/msx.png?branch=master)](http://travis-ci.org/insin/msx)
*MSX is based on version 0.13.2 of React's JSX Transformer*
MSX tweaks [React](http://facebook.github.io/react/)'s JSX Transformer to output
contents compatible with [Mithril](http://lhorie.github.io/mithril/)'s
`m.render()` function, allowing you to use HTML-like syntax in your Mithril
view code, like this:```html
var todos = ctrl.list.map(function(task, index) {
return
{task.title()}
})
```
## HTML tags and custom elements
For tag names which look like HTML elements or custom elements (lowercase,
optionally containing hyphens), raw virtual DOM objects - matching the
[`VirtualElement` signature](http://lhorie.github.io/mithril/mithril.render.html#signature)
accepted by `m.render()` - will be generated by default.
_Input:_
```html
Test
```
_Output:_
```javascript
{tag: "div", attrs: {id:"example"}, children: [
{tag: "h1", attrs: {}, children: ["Test"]},
{tag: "my-element", attrs: {name:"test"}}
]}
```
This effectively [precompiles](http://lhorie.github.io/mithril/optimizing-performance.html)
your view code for a slight performance tweak.
## Mithril components
Otherwise, it's assumed a tag name is a reference to an in-scope variable which
is a [Mithril component](http://lhorie.github.io/mithril/components.html).
Passing attributes or children to a component will generate a call to Mithril's
[`m.component()`](http://lhorie.github.io/mithril/mithril.component.html)
function, with children always being passed as an Array:
_Input:_
```html
{/* Bare component */}
{/* Component with attributes */}
{/* Component with attributes and children */}
{ctrl.files().map(file => )}
Upload
```
_Output:_
```javascript
{tag: "form", attrs: {}, children: [
/* Bare component */
Uploader,
/* Component with attributes */
m.component(Uploader, {onchange:ctrl.files}),
/* Component with attributes and children */
m.component(Uploader, {onchange:ctrl.files}, [
ctrl.files().map(function(file) {return m.component(File, Object.assign({}, file));})
]),
{tag: "button", attrs: {type:"button", onclick:ctrl.save}, children: ["Upload"]}
]}
```
MSX assumes your component's (optional) `controller()` and (required) `view()`
functions have the following signatures, where `attributes` is an `Object` and
`children` is an `Array`:
```javascript
controller([attributes[, children]])
view(ctrl[, attributes[, children]])
```
As such, if a component has children but no attributes, an empty attributes
object will still be passed:
_Input:_
```html
```
_Output:_
```javascript
m.component(Field, {}, [
{tag: "input", attrs: {onchange:m.withAttr('value', ctrl.description), value:ctrl.description()}}
])
```
## JSX spread attributes and `Object.assign()`
If you make use of [JSX Spread Attributes](http://facebook.github.io/react/docs/jsx-spread.html),
the resulting code will make use of `Object.assign()` to merge attributes - if
your code needs to run in environments which don't implement `Object.assign()`
natively, you're responsible for ensuring it's available via a
[shim](https://github.com/ljharb/object.assign), or otherwise.
Other than that, the rest of React's JSX documentation should still apply:
* [JSX in Depth](http://facebook.github.io/react/docs/jsx-in-depth.html)
* [JSX Spread Attributes](http://facebook.github.io/react/docs/jsx-spread.html)
* [JSX Gotchas](http://facebook.github.io/react/docs/jsx-gotchas.html) - with
the exception of `dangerouslySetInnerHTML`: use
[`m.trust()`](http://lhorie.github.io/mithril/mithril.trust.html) on contents
instead.
* [If-Else in JSX](http://facebook.github.io/react/tips/if-else-in-JSX.html)
## In-browser JSX Transform
For development and quick prototyping, an in-browser MSX transform is available.
Download or use it directly from cdn.rawgit.com:
* https://cdn.rawgit.com/insin/msx/master/dist/MSXTransformer.js
Include a `` tag to engage the MSX transformer.
To enable ES6 transforms, use `<script type="text/msx;harmony=true">`. Check out
the [source](https://github.com/insin/msx/blob/master/demo/index.html) of the
[live example of using in-browser JSX + ES6 transforms](http://insin.github.io/msx/).
Here's a handy template you can use:
```html
<meta charset="UTF-8">
<script src="https://cdnjs.cloudflare.com/ajax/libs/mithril/0.2.0/mithril.js">
void function() { 'use strict';
var Hello = {
controller() {
this.who = m.prop('World')
},
view(ctrl) {
return <h1>Hello {ctrl.who()}!</h1>
}
}
m.mount(document.getElementById('app'), Hello)
}()
```
## Command Line Usage
```
npm install -g msx
```
```
msx --watch src/ build/
```
To disable precompilation from the command line, pass a `--no-precompile` flag.
Run `msx --help` for more information.
## Module Usage
```
npm install msx
```
```javascript
var msx = require('msx')
```
### Module API
#### `msx.transform(source: String[, options: Object])`
Transforms XML-like syntax in the given source into object literals compatible
with Mithril's `m.render()` function, or to function calls using Mithril's
`m()` function, returning the transformed source.
To enable [ES6 transforms supported by JSX Transformer](http://kangax.github.io/compat-table/es6/#jsx),
pass a `harmony` option:
```javascript
msx.transform(source, {harmony: true})
```
To disable default precompilation and always output `m()` calls, pass a
`precompile` option:
```javascript
msx.transform(source, {precompile: false})
```
## Examples
Example inputs (using some ES6 features) and outputs are in
[test/jsx](https://github.com/insin/msx/tree/master/test/jsx) and
[test/js](https://github.com/insin/msx/tree/master/test/js), respectively.
An example [gulpfile.js](https://github.com/insin/msx/blob/master/gulpfile.js)
is provided, which implements an `msxTransform()` step using `msx.transform()`.
## Related Modules
* [gulp-msx](https://github.com/insin/gulp-msx) - gulp plugin.
* [grunt-msx](https://github.com/hung-phan/grunt-msx) - grunt plugin.
* [mithrilify](https://github.com/sectore/mithrilify) - browserify transform.
* [msx-loader](https://github.com/sdemjanenko/msx-loader) - webpack loader.
* [babel-plugin-mjsx](https://github.com/Naddiseo/babel-plugin-mjsx) - babel transform
## MIT Licensed