<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) {
e.preventDefault();
// 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": {}
};
// Specify the file name, default to file.txt.
var fileName = document.querySelector('#file-name').value || 'file.txt';
data.files[fileName] = {
"content": document.querySelector('textarea').value
}
var url = form.getAttribute('action');
var options = {
headers: {
'Content-Type': 'application/json;charset=UTF-8'
},
method: form.getAttribute('method'),
body: JSON.stringify(data)
}
// https://developer.mozilla.org/en-US/docs/Web/API/GlobalFetch/fetch
fetch(url, options).then(function(response) {
response.json().then(function(json) {
// Show a link to the gist.
var gistLink = doc.createElement('a');
gistLink.setAttribute('href', json.html_url);
gistLink.innerHTML = json.html_url;
doc.body.appendChild(gistLink);
});
}).catch(function(error) {
console.log('error creating gist', error);
});
}, false);
});
})(this, this.document);
</script>
</body>
</html>
Output
300px
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. |