<html>
<head>
<script src="//code.jquery.com/jquery-2.1.1.min.js"></script>
<meta charset="utf-8">
<title>JS Bin</title>
</head>
<body>
<table><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr></table>
<select><option></option><option value="wood">Wood</option><option value="clay">Clay</option></select>
<div id="object"></div>
<button id="clear">Clear</button>
<p>Select your material from the dropdown, then place them in the grid..</p>
<p>Try a table... 3 in a row, and a leg either side...</p>
<p>..or a clay pot... 3 items of clay in a V shape...</p>
</body>
</html>
table {
border-collapse:collapse;
}
table td {
margin:0; padding:0;
width:30px;
height:30px;
border:1px dashed #ccc;
background-color:#efefef;
}
button {
margin:20px;
float:left;
}
p {
float:left;
clear:left;
display:block;
}
.icon {
background:url() no-repeat 0 30px;
}
.wood {
background-position:0 0
}
.clay {
background-position:-30px 0;
}
.table {
background-position:-60px 0;
}
.pot {
background-position:-90px 0;
}
select {
float:left;
margin:20px;
}
#object {
width:30px;
height:30px;
border:1px solid black;
float:left;
margin:15px;
}
$('td').each(function() {
$(this).click(function() {
var selected = $('select').val();
if (selected) {
$(this).removeClass().addClass('icon '+selected);
} else {
$(this).removeClass();
}
evaluate();
});
});
$('#clear').click(function() {
$('td').removeClass();
evaluate();
})
function evaluate() {
var craft = '';
$('table').find('tr').each(function() {
$(this).find('td').each(function() {
var cell = $(this);
var item = '-';
if (cell.hasClass('wood')) item = 'w';
if (cell.hasClass('clay')) item = 'c';
craft += item;
});
craft += '@';
});
var recipes = [
{ pattern: /^[-@]*www[-@]{6}w-w[-@]*$/i, object: 'table'},
{ pattern: /^[-@]*c-c[-@]{7}c[-@]*$/i, object: 'pot'}
];
var matched = false;
recipes.forEach(function(recipe) {
if (recipe.pattern.test(craft)) {
matched = recipe;
}
});
$('#object').removeClass().addClass('icon '+matched.object);
}
Output
This bin was created anonymously and its free preview time has expired (learn why). — Get a free unrestricted account
Dismiss xKeyboard Shortcuts
Shortcut | Action |
---|---|
ctrl + [num] | Toggle nth panel |
ctrl + 0 | Close focused panel |
ctrl + enter | Re-render output. If console visible: run JS in console |
Ctrl + l | Clear the console |
ctrl + / | Toggle comment on selected lines |
ctrl + ] | Indents selected lines |
ctrl + [ | Unindents selected lines |
tab | Code complete & Emmet expand |
ctrl + shift + L | Beautify code in active panel |
ctrl + s | Save & lock current Bin from further changes |
ctrl + shift + s | Open the share options |
ctrl + y | Archive Bin |
Complete list of JS Bin shortcuts |
JS Bin URLs
URL | Action |
---|---|
/ | Show the full rendered output. This content will update in real time as it's updated from the /edit url. |
/edit | Edit the current bin |
/watch | Follow a Code Casting session |
/embed | Create an embeddable version of the bin |
/latest | Load the very latest bin (/latest goes in place of the revision) |
/[username]/last | View the last edited bin for this user |
/[username]/last/edit | Edit the last edited bin for this user |
/[username]/last/watch | Follow the Code Casting session for the latest bin for this user |
/quiet | Remove analytics and edit button from rendered output |
.js | Load only the JavaScript for a bin |
.css | Load only the CSS for a bin |
Except for username prefixed urls, the url may start with http://jsbin.com/abc and the url fragments can be added to the url to view it differently. |