Problem with async function not being called in javascript
Solution 1:
Here is a corrected snippet. @Quentin already pointed out that the id "login" was missing.
const form = document.getElementById('login')
form.addEventListener('submit', login)
async function login(event) {
console.log('logging in ...')
event.preventDefault()
const username = document.getElementById('username').value
const password = document.getElementById('password').value
const url='https://jsonplaceholder.typicode.com/users/'; // '/api/login'
const result = await fetch(url, {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({
username,
password
})
}).then((res) => res.json())
if (result.status !== 'ok') {
// everything went fine
console.log('Got the token: ', result)
// localStorage.setItem('token', result.id)
alert('Success')
} else {
if (result.status === 'Not Found') {
alert("Incorrect Username and/or Password!");
} else {
alert("Please enter Username and Password!");
}
}
}
<body class="hero-image">
<div id="container">
<div id="tabs">
<p id="lt" class="tabs">Log in</p>
<p id="rt" class="tabs" onclick="location.href = './register';">Register</p>
<div id="clear"></div>
</div>
<div id="cont">
<div id="loginBox" class="comm">
<h3>Sign in</h3>
<form action="/api/login" method="POST" id="login">
<input id="username" type="text" autocomplete="off" name="username" placeholder="Username" required>
<input id="password" type="password" autocomplete="off" name="password" placeholder="Password" required>
<input type="submit" value="Submit Form">
</form>
</div>
</div>
</div>
</body>