首页 > 解决方案 > 使用 JavaScript 更改元素的显示时添加平滑过渡

问题描述

我在标题中添加了一个默认设置为的搜索栏,我使用 js 通过分配一个包含搜索栏元素 ( )的类display: none来使其出现在按钮单击上。它工作正常,但我唯一的问题是从到的粗略过渡,所以我一直在寻找使这种过渡顺利的方法,我发现的大多数答案都是使用 jQuery,因为我真的不想这样做我仍处于 js 的学习阶段,所以如果有办法使用 vanilla js 做到这一点,请帮助我。.showdisplay: block !important#searchdisplay: noneblock

这是我的代码https://jsfiddle.net/5jxLq9ck/

在 CSS 第 38 行,我添加了.show实用程序类

.show {
    display: block !important;
}

而且我假设我必须在这里(js)编辑一些东西以获得预期的效果:

function showSearch(e) {
    e.preventDefault;
    if (
        e.target.classList.contains("show-btn") ||
        e.target.classList.contains("fas")
    ) {
        const searchBar = document.querySelector("#search");
        searchBar.classList.add("show");
    }
}

附加问题:我在这里使用e.preventDefault正确吗?在我使用它之前,该功能不起作用。

提前非常感谢。

标签: javascriptcss

解决方案


这是一个更新的片段,我更改width了动画的输入。您可以通过设置 input 使其更加流畅height

const searchDiv = document.querySelector("#search-div");

// ADD EVENT LISTENERS
searchDiv.addEventListener("click", showSearch);

// FUNCTION: SHOW SEARCH BAR ON BUTTON CLICK
function showSearch(e) {
    e.preventDefault;
    if (
        e.target.classList.contains("show-btn") ||
        e.target.classList.contains("fas")
    ) {
        const searchBar = document.querySelector("#search");
        searchBar.classList.add("show");
    }
}
/* GENERAL */
:root {
    --light-color: #ccc;
    --lighter-color: #f4f4f4;
    --dark-color: #333;
    --darker-color: #222;
    --brand-color: #ff4;
    --danger: #f44;
    --danger-dark: #c00;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    background: var(--dark-color);
    color: var(--light-color);
    font-family: "Trebuchet MS";
}

ul li {
    list-style: none;
}

button,
input {
    outline: none;
}

/* UTILITY */
.highlight {
    color: var(--brand-color);
}

.show {
    width: 300px !important;
    border: black 2px solid;
    padding: 0.6rem 1rem;
}

/* HEADER */
header {
    background: var(--darker-color);
    display: flex;
    flex-direction: row;
    align-items: center;
    text-align: center;
    justify-content: space-between;
    padding: 1.4rem 6rem;
    width: 100%;
}

#logo {
    font-size: 2.4rem;
    font-weight: 200;
}

#search-div {
    width: auto;
    height: auto;
    display: flex;
    gap: 0.4rem;
}

.show-btn {
    padding: 0.6rem 0.7rem;
    background: var(--light-color);
    border-radius: 5px;
    border: none;
    transition: ease-in 300ms;
    font-size: 1.2rem;
    cursor: pointer;
    height: 100%;
    margin-top: 2px;
}

.show-btn:hover {
    background: var(--brand-color);
    transition: ease-in 300ms;
}

#search {
    width: 0;
    background: var(--lighter-color);
    color: var(--darker-color);
    height: 100%;
    font-size: 1.2rem;
    border-radius: 2px;
    transition: ease-in 300ms;
    border: none;
}
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>My Contact List</title>
    <link rel="stylesheet" href="css/style.css">
    <script src="https://kit.fontawesome.com/3ad7573e76.js" crossorigin="anonymous"></script>
</head>

<body>
    <header>
        <div id="logo-div">
            <h1 id="logo">
                <span class="highlight"><i class="fas fa-user-friends"></i></span> My<span
                    class="highlight">Contact</span>List
            </h1>
        </div>
        <div id="search-div">
            <button class="show-btn"><i class="fas fa-search"></i></button>
            <input id="search" type="text" placeholder="Search contacts...">
        </div>
    </header>

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

</html>


推荐阅读