<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<!-- initialize google login api, for user authentication -->
<meta name="google-signin-client_id" content="247219641427-ifeq88p7rgor9al5ksduds7ug0ba7djr.apps.googleusercontent.com">
<script src="https://apis.google.com/js/platform.js" async defer></script>
</head>
<body>
<p>Connexion:
<div class="g-signin2" data-onsuccess="onSignIn"></div>
<a href="#" onclick="gapi.auth2.getAuthInstance().signOut(); return false;">Sign out</a>
</p>
<p>Twittez:</p>
<!-- Solution de l'exercice: -->
<input id="message" placeholder="Votre message">
<button id="bouton">Envoyer</button>
<!-- fin de la solution -->
</body>
</html>
// --- code fourni ---
function onSignIn(googleUser) {
window.token = googleUser.getAuthResponse().id_token;
(document.getElementById('tokenInput') || {}).value = token;
}
// --- fin du code fourni ---
// Solution de l'exercice:
var message = document.getElementById('message');
function sendMessage() {
// pas la peine d'envoyer le message s'il est vide
if (message.value.length === 0) {
return;
}
// initialisation de la requête AJAX POST au serveur
var xhr = new XMLHttpRequest();
xhr.open('POST', 'https://js-ajax-twitter.herokuapp.com/tweet');
xhr.onreadystatechange = function() {
if (xhr.readyState === 4) {
console.log('Réponse finale du serveur:', xhr.responseText);
var responseObject = JSON.parse(xhr.responseText);
if (responseObject.error) {
alert('Erreur: ' + responseObject.error);
} else {
console.log('Message envoyé avec succès :-)');
message.value = '';
}
}
};
// envoi de la requête avec les propriétés message et token (comme spécifié dans la documentation de l'API)
xhr.send(JSON.stringify({
message: message.value,
token: window.token, // fourni dans le code HTML
}));
}
// l'évènement "click" est émis par le bouton quand l'utilisateur clique dessus
document.getElementById('bouton').onclick = function() {
console.log('L\'utilisateur a cliqué sur le bouton');
sendMessage();
};
// l'évènement "change" est émis par l'input quand l'utilisateur valide
document.getElementById('message').onchange = function() {
console.log('L\'utilisateur a pressé ENTRÉE');
sendMessage();
};
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. |