Создание 2 кнопок, которые показывают контент с 2 разных направлений - PullRequest
0 голосов
/ 11 февраля 2020

Я хочу создать 2 кнопки, может при нажатии будет отображаться соответствующий контент с 2 разных направлений. enter image description here

Пример:

Когда пользователь нажимает smt, содержимое открывается слева. Когда пользователь нажимает mi, содержимое открывается справа.

Пока мне удалось выполнить часть smt только потому, что я не знаю, как сделать часть "mi" работа.

Ниже мой код:

Стиль:

<style>
    .overlay {
        height: 100%;
        width: 0;
        position: fixed;
        z-index: 1;
        top: 60;
        left: 0;
        background-color: rgb(0, 0, 0);
        background-color: rgba(0, 0, 0, 0.9);
        overflow-x: hidden;
        transition: 0.5s;
    }

    .overlay-content {
        position: relative;
        top: 25%;
        width: 100%;
        text-align: center;
        margin-top: 30px;
    }

    .overlay a {
        padding: 8px;
        text-decoration: none;
        font-size: 36px;
        color: #818181;
        display: block;
        transition: 0.3s;
    }

    .overlay a:hover, .overlay a:focus {
        color: #f1f1f1;
    }

    .overlay .closebtn {
        position: absolute;
        top: 60px;
        right: 45px;
        font-size: 60px;
    }

    @media screen and (max-height: 650px) {
        .overlay a {
            font-size: 20px
        }

        .overlay .closebtn {
            font-size: 40px;
            top: 15px;
            right: 35px;
        }
    }
</style>

Кнопка SMT:

<div id="myNav" class="overlay">
    <a href="javascript:void(0)" class="closebtn" onclick="closeNav()">&times;</a>
    <div class="overlay-content">Smt</div>
</div>
<span style="font-size:30px;cursor:pointer; position:absolute; top:680px; left:300px;" onclick="openNav()">smt</span>

JavaScript:

<script>
    function openNav() {
        document.getElementById( "myNav" ).style.width = "100%";
    }

    function closeNav() {
        document.getElementById( "myNav" ).style.width = "0%";
    }
</script>

Как я могу повторно использовать тот же код для второй кнопки?

Ответы [ 3 ]

3 голосов
/ 11 февраля 2020

Я думаю, что вы ищете это .. Может быть, это может помочь вам

Я использую jquery-ui, функция slide для достижения эффекта желания

Использование одного контента

$('#loginPanel').click(function(){
            
                if ($('#userNav').is(':hidden')) {
                   
                   $('#userNav').show('slide',{direction:'left'},1000);
                } else {
                   
                   $('#userNav').hide('slide',{direction:'left'},1000);
                }
});

$('#loginPanel1').click(function(){
            
                if ($('#userNav').is(':hidden')) {
                   
                   $('#userNav').show('slide',{direction:'right'},1000);
                } else {
                   
                   $('#userNav').hide('slide',{direction:'right'},1000);
                }
});
a {
    color: #000;
    cursor:pointer;
    display:block;
}

#userNav{
    width: 200px;
    height: 200px;
    display: none;
    background: #ff0000;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="http://code.jquery.com/ui/1.10.2/jquery-ui.js"></script>
<button id="loginPanel">left-to-right</button>
<button id="loginPanel1">right-to-left</button>

<div id="userNav">User Area</div>

Использование отдельного контента (я использую flex, чтобы сделать оба контента встроенными, вы можете просто удалить класс main-content, чтобы показать их в отдельной строке как block)

$('#loginPanel').click(function(){
            
                if ($('#userNav').is(':hidden')) {
                   
                   $('#userNav').show('slide',{direction:'left'},1000);
                } else {
                   
                   $('#userNav').hide('slide',{direction:'left'},1000);
                }
});

$('#loginPanel1').click(function(){
            
                if ($('#userNav1').is(':hidden')) {
                   
                   $('#userNav1').show('slide',{direction:'right'},1000);
                } else {
                   
                   $('#userNav1').hide('slide',{direction:'right'},1000);
                }
});
a {
    color: #000;
    cursor:pointer;
    display:block;
}

.area{
    width: 200px;
    height: 200px;
    display: none;
    background: #ff0000;
}
.main-content {
    display: flex;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="http://code.jquery.com/ui/1.10.2/jquery-ui.js"></script>
<button id="loginPanel">left-to-right</button>
<button id="loginPanel1">right-to-left</button>
<div class="main-content">
<div class="area" id="userNav">User Area 1</div>

<div class="area" id="userNav1">User Area 2</div>
</div>
2 голосов
/ 11 февраля 2020

Вы можете передать идентификатор функции следующим образом:

onclick="openNav("myNav1")"

И если вам нужно скрыть элемент, вы можете использовать: display: "none"

<script>
    function openNav(id) {
        document.getElementById(id).style.display = "block";
    }

    function closeNav(id) {
        document.getElementById(id).style.display = "none";
    }
</script>
0 голосов
/ 12 февраля 2020

Просто нужно сделать это для кода:

Добавить «2» в «openNav», «myNav2», «closeNav2»

< script>
function openNav2() {
    document.getElementById( "myNav2" ).style.width = "100%";
}

function closeNav2() {
    document.getElementById( "myNav2" ).style.width = "0%";
}
</script>

То же самое для кода кнопки, добавить «2» - «myNav», «openNav», «closeNav»

<div id="myNav" class="overlay">
<a href="javascript:void(0)" class="closebtn" onclick="closeNav()">&times;</a>
<div class="overlay-content">MI</div>
</div>
<span style="font-size:30px;cursor:pointer; position:absolute; top:680px; 
left:300px;" onclick="openNav()">MI</span>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...