Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
<head>
<script src="//code.jquery.com/jquery.min.js"></script>
<link href="//netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" type="text/css" />
<script src="//netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script>
<!-- uncomment for React master
<script src="http://react.zpao.com/builds/master/latest/react.min.js"></script>
-->
<script src="//fb.me/react-with-addons-0.12.2.js"></script>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
</body>
</html>
 
    var SearchResult = React.createClass({
      getInitialState: function () {
        return {
          site: '',
          address: ''
        };
      },
      onSiteChanged: function (e) {
        this.setState({
          site: e.currentTarget.value
          });
      },
      
      onAddressChanged: function (e) {
        this.setState({
          address: e.currentTarget.value
          });
      },
      
      render: function(){
           var resultRows = this.props.data.map(function(result){
               return (
                   <tbody>
                        <tr>
                            <td><input type="radio" name="site_name" 
                                       value={result.SITE_NAME} 
                                       checked={this.state.site === result.SITE_NAME} 
                                       onChange={this.onSiteChanged} />{result.SITE_NAME}</td>
                            <td><input type="radio" name="address" 
                                       value={result.ADDRESS}  
                                       checked={this.state.address === result.ADDRESS} 
                                       onChange={this.onAddressChanged} />{result.ADDRESS}</td>
                        </tr>
                   </tbody>
               );
           }, this);
           return (
               <table className="table">
                   <thead>
                       <tr>
                           <th>Name</th>
                           <th>Address</th>
                       </tr>
                   </thead>
                    {resultRows}
                   <tfoot>
                       <tr>
                           <td>chosen site name {this.state.site} </td>
                           <td>chosen address {this.state.address} </td>
                       </tr>
                   </tfoot>
               </table>
           );
      }
    });
var App = React.createClass({
  render: function(){
    return <div><SearchResult data={[
      {SITE_NAME: 'google.com', ADDRESS: 'Mountain View, CA'},
      {SITE_NAME: 'example.com', ADDRESS: 'Example Place, CA'}
    ]}/></div>
  }
});
React.render(<App />, document.body);
Output 300px

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

Dismiss x
public
Bin info
anonymouspro
0viewers