<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>注册页面</title> </head> <body> <form id="enroll"> <h1>注册账号</h1><br><br> <label for="name">名 字:</label><input type="text" id="name" value="" ><br><br> <label for="mail">邮 箱:</label><input type="text" id="mail" value=""><br><br> <label for="password1">密 码:</label><input type="text" id="password1" value=""><br><br> <label for="password2">确认密码:</label><input type="text" id="password2" value=""><br><br> <button type="reset" value="重置">重置</button> <button type="button" value="提交" onclick="namejudge(username,usermail,userpass1,userpass2)" >提交</button> <script> var username = document.getElementById('name').value; var usermail = document.getElementById('mail').value; var userpass1 = document.getElementById('password1').value; var userpass2 = document.getElementById('password2').value; function namejudge(username,usermail,userpass1,userpass2) { if (username===''||userpass1===''||usermail===''||userpass2===''){alert('用户信息不能为空')} else{alert(username+usermail+userpass1+userpass2)} } </script> </form> </body> </html>这段代码为什么不能在浏览器中打印我输入的用户信息
时间: 2023-08-14 18:10:21 浏览: 91
这段代码不能在浏览器中打印用户输入的信息,因为在你定义变量 username、usermail、userpass1 和 userpass2 时,它们的值为空字符串。这是因为你在页面加载时就将这些输入框的值获取了,此时输入框还没有内容,所以变量的值为空字符串。当你点击提交按钮时,调用的函数 namejudge() 中,这些变量的值并没有重新获取输入框的内容,仍然是空字符串,因此无法正确输出用户的输入信息。
为了解决这个问题,你需要将获取输入框的值的代码放到 namejudge() 函数内部,这样当你点击提交按钮时才会获取最新的输入框内容。修改后的代码如下:
```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>注册页面</title>
</head>
<body>
<form id="enroll">
<h1>注册账号</h1><br><br>
<label for="name">名 字:</label><input type="text" id="name" value="" ><br><br>
<label for="mail">邮 箱:</label><input type="text" id="mail" value=""><br><br>
<label for="password1">密 码:</label><input type="text" id="password1" value=""><br><br>
<label for="password2">确认密码:</label><input type="text" id="password2" value=""><br><br>
<button type="reset" value="重置">重置</button>
<button type="button" value="提交" onclick="namejudge()" >提交</button>
<script>
function namejudge() {
var username = document.getElementById('name').value;
var usermail = document.getElementById('mail').value;
var userpass1 = document.getElementById('password1').value;
var userpass2 = document.getElementById('password2').value;
if (username===''||userpass1===''||usermail===''||userpass2===''){
alert('用户信息不能为空');
}
else{
alert(username+usermail+userpass1+userpass2);
}
}
</script>
</form>
</body>
</html>
```
注意,在按钮的 onclick 事件中不再传递参数,因为在函数内部重新获取了输入框的值。
阅读全文