开发者问题收集

我无法在 javascript 中更改类的显示

2022-06-04
282

我正在尝试更改 JavaScript 中元素的可见性。

我尝试使用控制台窗口运行 openloginHud(); ,它响应未定义

我也尝试使用控制台,它告诉我错误是

Uncaught TypeError: Cannot read properties of null (reading 'style') at openloginHud (index.js:20:40) at HTMLInputElement.onclick (index.html:13:110)

我的代码

HTML:

<div class="login"><input id="login" type="submit" name="login" onclick="openloginHud();" value="Login"/></div>
<div class="loginHud">
        <div class="inputs">
            <h1>Login</h1>
            <div class="email"><input type="email" name="email" id="email" placeholder="Email"></div>
            <div class="password"><input type="password" name="password" id="pass" placeholder="Password"></div>
            <div class="submit"><input id="submit" type="submit" name="Login" onclick="login();" value="Login"/></div>
        </div>
    </div>

JavaScript:

function openloginHud() {
    document.getElementById("loginHud").style.display = "block";
}

Css:

.inputs {
    background-color: rgb(94, 94, 94);
    position: absolute;
    display: none;
    left: 50%;
    top: 40%;
    transform: translate(-50%, -50%);
    padding: 0 100px;
    padding-top: 50px;
    padding-bottom: 100px;
    border-radius: 55px;
}

.inputs .email {
    padding-bottom: 15px;
}

.inputs .email input,
.inputs .password input {
    padding: 10px;
    background: none;
    outline: none;
    border: 5px solid white;
    border-radius: 15px;
    color: white;
}

.inputs .email input::placeholder,
.inputs .password input::placeholder {
    color: rgb(199, 199, 199);
}

.inputs h1 {
    color: white;
    font-size: 65px;
    text-align: center;
}

.inputs .password input,
.inputs .email input {
    height: 20px;
    width: 250px;
}
2个回答

将 “document.getElementbyID” 更改为

function openloginHud() {
    document.querySelector(".loginHud").style.display = "block";
}

querySelector 允许您使用 CSS 选择器,如“#”和“。”。它使在两种类型之间无缝切换变得更加容易。只需记住使用 CSS 选择器,它就会改变样式。

user3851512
2022-06-04

loginHud 是一个类,而不是 ID。您有 2 个选择:

如果只有一个元素属于该类,则将其更改为 ID:

<div id="loginHud">

如果有多个元素,请使用 getElementsByClassName 并循环遍历它:

for (let el of document.getElementsByClassName('loginHud')) {
    el.style.display = 'block';
}
asportnoy
2022-06-04