Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
<head>
  <link href="//cdn.jsdelivr.net/picnicss/4.1.1/picnic.min.css" rel="stylesheet">
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
  <h1>Hello Mag.JS!</h1>
  <a target="_top" href="https://github.com/magnumjs/mag.js">GitHub</a>
  <hr/>
  <div id="greeting-div"></div>
  <script src="//rawgit.com/magnumjs/mag.js/master/dist/mag.0.23.1.min.js"></script>
  <script src="//rawgit.com/magnumjs/mag.js/master/src/addons/jsonml/affix.js"></script>
</body>
</html>
 
/* MagJS Example - Boilerplate v0.23 - Random Message components */
//From: http://www.sitepoint.com/getting-started-react-jsx/
//Html fixture for isolated dynamic dom generation
var fixture = 'div MessageView + p input[type="button"][value="Change Message"]';
var RandomMessage = mag.create(affix(fixture), {
  controller: function(props) {
    props.message = 'Hello, Universe';
    props.onClick = function() {
      var messages = ['Hello, World', 'Hello, Planet', 'Hello, Universe'];
      var randomMessage = messages[Math.floor((Math.random() * 3))];
      props.message = randomMessage;
    };
  },
  view: function(state, props) {
    state.MessageView = MessageView({
      message: props.message
    });
    state.input = {
      _onClick: props.onClick
    };
  }
});
//Dummy component:
var MessageView = mag.create(affix('div p'), {
  view: function(state, props) {
    state.p = props.message;
  }
});
//Mount:
mag.module(document.body, {
  view: function(state) {
    state.div = RandomMessage();
  }
});
Output 300px

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
anonymouspro
0viewers