<html>
<head>
<title></title>
<style>
body {
margin: 1em auto;
max-width: 40em;
width: 100%;
}
a, label, textarea, button {
display: block;
}
</style>
</head>
<body>
<form method="post" action="https://api.github.com/gists">
<label for="file-name">File name:</label>
<input type="text" id="file-name">
<label for="content">Gist content:</label>
<textarea id="content"></textarea>
<button type="submit">Post</button>
</form>
<div>Gists created so far:</div>
<script>
(function (win, doc) {
// Find form elements.
var forms = doc.querySelectorAll('form[method="post"]');
// Prevent submit, do an xhr instead.
forms.forEach(function(form) {
form.addEventListener('submit', function (e) {
// Create the object structure gist.github.com expects:
// https://developer.github.com/v3/gists/#create-a-gist
var data = {
"description": "anonymous gists from a form",
"public": false,
"files": {}
};
var fileName = document.querySelector('#file-name').value || 'file.txt';
data.files[fileName] = {
"content": document.querySelector('textarea').value
}
e.preventDefault();
var xhr = new XMLHttpRequest();
var method = form.getAttribute('method');
var url = form.getAttribute('action');
xhr.open(method, url, true);
// Change the content-type from the default of application/x-www-form-urlencoded
// https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest#Using_nothing_but_XMLHttpRequest
xhr.setRequestHeader('Content-Type', 'application/json;charset=UTF-8');
xhr.onload = function(e) {
var gistUrl = JSON.parse(e.target.response).html_url;
// Show a link to the gist.
var gistLink = doc.createElement('a');
gistLink.setAttribute('href', gistUrl);
gistLink.innerHTML = gistUrl;
doc.body.appendChild(gistLink);
};
xhr.send(JSON.stringify(data));
}, false);
});
})(this, this.document);
</script>
</body>
</html>
Output
You can jump to the latest bin by adding /latest
to your URL
Keyboard 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. |