gpt4 book ai didi

javascript - 为什么我无法在 JavaScript 中获得任何输出?

转载 作者:行者123 更新时间:2023-11-30 07:24:39 24 4
gpt4 key购买 nike

我刚刚创建了一个表单,并试图获取表单元素的值,我使用的这段代码有什么问题?

<!DOCTYPE html>

<html>
<head>
<title>JavaScript Practice</title>
<style type="text/css">
*{
font-family:ebrima;
}
</style>

</head>

<body>
<form name="myForm">
Username: <input type="text" id="nameSpace"><br />
Password: <input type="text" style="margin-left:5px;" id="passSpace"><br />
<button type="button" onClick="login()" name="login" style="margin-left:210px;" value="Login">Login!</button>
</form>
<p id="demo"></p>

<script>
function login() {
var username = document.getElementById('nameSpace').value;
document.getElementById('demo').innerHTML=username;
}
</script>
</body>
</html>

最佳答案

您的函数与元素的 ID/名称同名。它正在被对 DOM 对象的引用覆盖。

先花 10 分钟诅咒微软留给我们这个遗产,然后重命名该函数。


一般而言,作为更好的解决方案:

  1. 使用 JavaScript 绑定(bind)您的事件处理程序,而不是使用内部事件属性
  2. 避免使用全局变量。

这样的:

<button type="button" id="login" name="login" style="margin-left:210px;" value="Login">Login!</button>

(function () { // Immediately invoked function for the purposes of limiting scope
function login() {
var username = document.getElementById('nameSpace').value;
document.getElementById('demo').innerHTML=username;
}
document.getElementById('login').addEventListener('click', login);
})();

备注compatibility issues with old IE .

关于javascript - 为什么我无法在 JavaScript 中获得任何输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21533034/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com