javascript - Javascript 中的 classList.toggle

标签 javascript class toggle contains


我试图在类不存在时将 .hidden 分配给某些元素,如果此类已分配给该元素,则删除类 .hidden 。换句话说 - 我只想切换类。

我写代码

var isHidden = document.getElementById("inputSelected").classList.toggle("hidden");

但它不起作用。但是当我控制台日志 classList.contains

var isHidden = document.getElementById("inputSelected").classList.contains("hidden");

它返回 false - 这意味着它没有分配这个类。那么为什么它不切换?

更多代码:

<!DOCTYPE html>
<html>
<head>
<title>Kalkulator dat</title>
<meta name="description" content="Kalkulator dat. Ile dni minęło od wskazanej daty? Jaka będzie data za daną ilość dni?">
<link rel="StyleSheet" type="text/css" href="style.css">
</head>

<body>
<h1>Kalkulator dat</h1>
<div id="daysPassed">
    <h2>Ile pełnych dni minęło?</h2>
    <form id=daysPassedForm">
        <label for="firstDateDP">Data początkowa:</label>
        <input type="date" id="firstDate">
        <fieldset>
            <input type="radio" id="toToday" name="todayOrSelected">    
            <label for="toToday">Do dziś</label>

            <input type="radio" id="toSelected" name="todayOrSelected"> 
            <label for="toSelected">Do wskazanej daty</label> 
            <p id="inputSelected">(<input type="date" id="selectedEndDate">)</p>

        </fieldset>
        <input type="submit" value="Oblicz">
        </form>
</div>

<div id="daysPassedResult" class="result">
    <p id="daysPassedInfo">Od wskazanej daty minęło x dni</p>
</div>

<div id="dateIndicate">
    <h2>Jaka będzie data?</h2>
    <form id="dateIndicateForm">
        <ul>
            <li>
                <label for="firstDateDI"><span>Data początkowa:</span></label>
                <input type="date" id="firstDateDI">
            </li>

            <li>
            <label for="numberOfDays"><span>Liczba pełnych dni:</span></label>
            <input type="number" id="numberOfDays" step="1">
            </li>

            <li>
            <input type="submit" value="Oblicz">
            </li>
        </ul>
    </form>
</div>

<div id="dateIndicateResult" class="result">
    <p id="dateIndicateResult">Po x dniach od y będzie</p>
</div>

<script src="script.js"></script>
</body>
</html>


div {
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box; 
margin-bottom: 7px;
}

body {
margin: 0 auto;
width: 40%;
background-color: #FFCA51;
}

div {
padding: 5px;
border-radius: 15px;
}

p {
margin: 8px 0 8px 0;
}

ul {
list-style-type: none;
padding: 0;
}

h1 {
text-align: center;}

fieldset {
border: none;
}

input {
margin: 2px;
padding: 1px;
}

span {
width: 115px;
text-align: right;
display: inline-block;
}


#daysPassed {
background-color: #E8A849;
padding-left: 16px;
}

#inputSelected {
margin: 0 0 0 8px;
display: inline-block;
}

#daysPassedResult {
background-color: #FFA75D;
}

#dateIndicate {
background-color: #E87A49;
padding-left: 16px;
margin-top: 20px;
}

#dateIndicateResult {
background-color: #FF6D51;
}

.result {
margin: 8px 0 8px 16px;
padding-left: 12px;
max-width: 50%;
}

.hidden {
display: none;}


function preparePage() {
    document.getElementById("inputSelected").classList.toggle("hidden");
    document.getElementById("daysPassedResult").classList.toggle("hidden");
    document.getElementById("dateIndicateResult").classList.toggle("hidden");
}

window.onload = function() {
    preparePage();
};

现在 preparePage 的第二行和第三行有效,但第一行 (#inputselected) 无效

最佳答案

DOMTokenList来自 Mozilla 的引用:

toggle ( token ) - removes token from string and returns false. If token doesn't exist it's added and the function returns true

您的代码确实有效,但问题似乎不是由 DOMTokenList .toggle() 函数引起的,而是由 CSS id #inputSelected 引起的:

#inputSelected {
  margin: 0 0 0 8px;
  display: inline-block; /* will never let .hidden to actually set the "display: none". */
}

.hidden {
  display: none;
}

修复它的一个简单方法是定义:

.hidden {
  display: none !important;
}

或在单独的类中定义 display: inline-block;

如果问题确实是 .toggleDOMTokenList 仍然有:

  • .contains
  • .add
  • .remove

否则,您可以使用 jQuery 或手动管理 element.className

关于javascript - Javascript 中的 classList.toggle,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25463653/

相关文章:

javascript - 将类添加到除第一个表之外的所有表

php - 如何检查自动加载是否只加载使用过的类?

javascript - Jquery Datatables - 使用复选框对 ID 组的最后一个元素进行自定义过滤

php - 在命名空间中扩展 PHP 类

php - 类中函数和公共(public)函数的区别

javascript - jQuery 切换延迟以及类和淡入淡出

jquery - 如何使用 jQuery 的切换返回元素状态?

c# - 是否有 WPF 复选框控件切换事件?

javascript - 尝试将生成的 PDF 文件从 React Js 发送到 Django-Rest Post 请求时未提交文件

javascript - 在 HTML5 Canvas 上同时追踪两条​​路径