Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   функция слайдера (https://javascript.ru/forum/dom-window/71817-funkciya-slajjdera.html)

3dartmax 14.12.2017 23:10

функция слайдера
 
народ помогите с функцией... никак не пойму как addEventListener связать с z-index
если можно с построчными коментами... заранее спс !

https://gist.github.com/archivisions...8ce81589646d3a
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<style>
body {
    box-sizing: border-box;
}
 
.slider {
    background-color: rgba(229, 255, 248, 0.28);
    width: 500px;
    height: 500px;
    align-content: center;
    position: relative;
    border: 1px solid black;
}
#previewRed {
     width: 300px;
     height: 400px;
     position: absolute;
     background: red;
     padding: 10px;
     border: 1px solid black;
    text-align: center;
    color: white;
    z-index: 1;
 
 }
#previewYellow {
     width: 300px;
     height: 400px;
     position: absolute;
     background: #fffb1d;
     padding: 10px;
     border: 1px solid black;
    z-index: 2;
 }
#previewGreen {
    width: 300px;
    height: 400px;
    position: absolute;
    background: #5dc35e;
    padding: 10px;
    border: 1px solid black;
    text-align: center;
    color: white;
    z-index: 3;
}
#previewBlue {
    width: 300px;
    height: 400px;
    position: absolute;
    background: #655bc3;
    padding: 10px;
    border: 1px solid black;
    text-align: center;
    color: white;
    z-index: 4;
}
 
 
.contrl {
    position: relative;
    width: 100px;
    height: 400px;
    border: 1px solid rgba(70, 243, 19, 0.58);
    margin-left: 350px;
}
 
#red {
    position: absolute;
    width: 75px;
    height: 75px;
    background: red;
    border: 1px solid black;
    margin: 10px;
    color: white;
}
#yellow {
    position: absolute;
    width: 75px;
    height: 75px;
    background: #fffb1d;
    border: 1px solid black;
    margin: 10px;
    top: 100px;
}
#green {
    position: absolute;
    width: 75px;
    height: 75px;
    background: #5dc35e;
    border: 1px solid black;
    margin: 10px;
    color: white;
    top: 200px;
}
#blue {
    position: absolute;
    width: 75px;
    height: 75px;
    background: #655bc3;
    border: 1px solid black;
    margin: 10px;
    color: white;
    top: 300px;
}
</style>
    
<body>
<div class="slider">
        <div id="previewRed">Red</div>
        <div id="previewYellow">Yellow</div>
        <div id="previewGreen">Green</div>
        <div id="previewBlue">Blue</div>
        <div class="contrl">
            <button id="red">Red</button>
            <button id="yellow">Yellow</button>
            <button id="green">Green</button>
            <button id="blue">Blue</button>
        </div>
</div>
<script src="script.js"></script>
</body>
</html>

рони 14.12.2017 23:25

3dartmax,
https://javascript.ru/forum/misc/715...tml#post471483

3dartmax 15.12.2017 01:14

Спасибо, принцип похож, но всетаки хотелось бы с z-index-ом чтото... просто хочу разобратся с css+js...

рони 15.12.2017 10:05

3dartmax,
к сожалению, код по ссылке это то, что вам нужно :) :(

рони 15.12.2017 10:49

делегирование , z-index
 
3dartmax,
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<style>
body {
    box-sizing: border-box;
}

.slider {
    background-color: rgba(229, 255, 248, 0.28);
    width: 500px;
    height: 500px;
    align-content: center;
    display: flex;
    justify-content: space-around;
    padding: 15px;
    border: 1px solid black;
}

.preview {
    width: 300px;
    height: 400px;
    position: absolute;
    padding: 10px;
    border: 1px solid black;
    text-align: center;
    color: white;
    z-index: 1;
    opacity: .3;
    transition: all .8s ease-in-out;
}

.contrl {
    position: relative;
    width: 100px;
    height: 400px;
    border: 1px solid rgba(70, 243, 19, 0.58);
    margin-left: 350px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.btn.red, .preview.red {
    background-color: red;
}
.btn.yellow, .preview.yellow  {
    background-color: #fffb1d;

}
.btn.green, .preview.green {
    background-color: #5dc35e;

}
.btn.blue, .preview.blue {
    background-color: #655bc3;

}

.btn{
    width: 75px;
    height: 75px;
    border: 1px solid black;
    margin: 10px;
    color: white;
    transition: all .3s ease-in-out;
}

.preview.act{
   z-index: 10;
   opacity: 1;
}
.btn.act {
   border-radius: 12px;
   border-width: thick;
}
:focus{
    outline:0;

  }

</style>
 <script src="https://cdn.polyfill.io/v1/polyfill.js?Element.prototype.closest"></script>

  <script>
 window.addEventListener("DOMContentLoaded", function() {
    var content = document.querySelector(".slider");
    content.addEventListener("click", function(event) {
        var target = event.target;
        if (target = target.closest(".btn")) {
            event.preventDefault();
            var a = content.querySelectorAll(".btn");
            var img = content.querySelectorAll(".preview");
            var selected = [].indexOf.call(a, target);
            [].forEach.call(a, function(el, i) {
                 (i == selected) ? (el.classList.add("act"), img[i].classList.add("act")):
                  (el.classList.remove("act"), img[i].classList.remove("act"))
            })
        }
    })
});
  </script>
<body>
<div class="slider">
        <div class="preview red act">Red</div>
        <div class="preview yellow">Yellow</div>
        <div class="preview green">Green</div>
        <div class="preview blue">Blue</div>
        <div class="contrl">
            <button class="btn red act">Red</button>
            <button class="btn yellow">Yellow</button>
            <button class="btn green">Green</button>
            <button class="btn blue">Blue</button>
        </div>
</div>

</body>
</html>

3dartmax 15.12.2017 12:59

Спасибо! а можете объяснить строку с 93 по 100? вроде вербально понятно, но уловить пока все не могу...

Nexus 15.12.2017 13:11

3dartmax, "вербально" - устно? На web-форуме?)
Если кликнули по элементу с классом "btn" или у элемента есть родитель с этим классом (строка 93), то отменяем действие по умолчанию (94).
Находим на на странице все элементы с классом "btn" (95) и "preview" (96).
Ищем индекс элемента в массиве "а", на котором произошел клик (97).
Обходим все элементы массива "а" в цикле (98).
Если это элемент, по которому кликнули (99, до "?"), то добавляем элементам с классом "btn" и "preview" под индексом "i" класс "act" (99, после "?"), в противном случае удаляем класс "act" у названных ранее элементов (100).

3dartmax 15.12.2017 13:21

Спасибо огромное, бум грызть дальше!

Dilettante_Pro 15.12.2017 13:24

Nexus,
У "вербально" значение не только устно, но и словесно.
Так что в результате вы совершенно правильно, вполне вербально ответили.

Nexus 15.12.2017 13:25

Dilettante_Pro, благодарю за разъяснение :)

3dartmax 15.12.2017 14:44

О. у нас кнопки с одинаковыми классами, а если их сделать разными классами? например redBtn,yellowBtn, greenBtn, blueBtn и actBtn тогда что в коде нужно сделать? Спасибо!

рони 15.12.2017 15:50

Цитата:

Сообщение от 3dartmax
что в коде нужно сделать?

Знаете ли вы селекторы?

https://javascript.ru/forum/misc/717...v-input-2.html

3dartmax 15.12.2017 16:36

window.addEventListener("DOMContentLoaded", function() {
    var content = document.querySelector(".slider");
    content.addEventListener("click", function(event) {
        var target = event.target;
        if (target = target.closest(".btn")) {
            event.preventDefault();
            var a = content.querySelectorAll("#redBtn, #yellowBtn, #greenBtn, #blueBtn");
            var img = content.querySelectorAll(".preview");
            var selected = [].indexOf.call(a, target);
            [].forEach.call(a, function(el, i) {
                 (i == selected) ? (el.classList.add("actBtn"), img[i].classList.add("act")):
                  (el.classList.remove("actBtn"), img[i].classList.remove("act"))
            })
        }
    })
});


Верно?

рони 15.12.2017 17:03

Цитата:

Сообщение от 3dartmax
Верно?

а проверить? 5-ю строку тоже нужно изменить, если вы убрали класс

рони 15.12.2017 17:08

3dartmax,
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<style>
body {
    box-sizing: border-box;
}

.slider {
    background-color: rgba(229, 255, 248, 0.28);
    width: 500px;
    height: 500px;
    align-content: center;
    display: flex;
    justify-content: space-around;
    padding: 15px;
    border: 1px solid black;
}

.preview {
    width: 300px;
    height: 400px;
    position: absolute;
    padding: 10px;
    border: 1px solid black;
    text-align: center;
    color: white;
    z-index: 1;
    opacity: .3;
    transition: all .8s ease-in-out;
}

.contrl {
    width: 100px;
    height: 400px;
    border: 1px solid rgba(70, 243, 19, 0.58);
    margin-left: 350px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.btn.red, .preview.red {
    background-color: red;
}
.btn.yellow, .preview.yellow  {
    background-color: #fffb1d;

}
.btn.green, .preview.green {
    background-color: #5dc35e;

}
.btn.blue, .preview.blue {
    background-color: #655bc3;

}

.btn{
    width: 75px;
    height: 75px;
    border: 1px solid black;
    margin: 10px;
    color: white;
    transition: all .3s ease-in-out;
}

.preview.act{
   z-index: 10;
   opacity: 1;
}
.btn.actBtn {
   border-radius: 12px;
   border-width: thick;
}
:focus{
    outline:0;

  }

</style>

  <script>
 window.addEventListener("DOMContentLoaded", function() {
    var content = document.querySelector(".slider");
    var a = content.querySelectorAll("#redBtn, #yellowBtn, #greenBtn, #blueBtn");
    var img = content.querySelectorAll(".preview");
    content.addEventListener("click", function(event) {
        var target = event.target;
        var selected = [].indexOf.call(a, target);
        if (selected !== -1) {
            event.preventDefault();
            [].forEach.call(a, function(el, i) {
                 (i == selected) ? (el.classList.add("actBtn"), img[i].classList.add("act")):
                  (el.classList.remove("actBtn"), img[i].classList.remove("act"))
            })
        }
    })
});

  </script>
<body>
<div class="slider">
        <div class="preview red act">Red</div>
        <div class="preview yellow">Yellow</div>
        <div class="preview green">Green</div>
        <div class="preview blue">Blue</div>
        <div class="contrl">
            <button class="btn red actBtn" id="redBtn">Red</button>
            <button class="btn yellow" id="yellowBtn">Yellow</button>
            <button class="btn green" id="greenBtn">Green</button>
            <button class="btn blue" id="blueBtn">Blue</button>
        </div>
</div>

</body>
</html>

3dartmax 15.12.2017 22:55

Понял, а без массива возможно реализовать также?

рони 15.12.2017 23:39

Цитата:

Сообщение от 3dartmax
без массива

?
не понимаю, без "делегирования" можно, назначить каждой кнопке клик.

3dartmax 16.12.2017 04:29

в самой функции или навесить клик на кнопки? подскажите плз...

рони 16.12.2017 09:29

3dartmax,
я пас, мне сложно понять ваши формулировки.

3dartmax 17.12.2017 02:31

я имею ввиду onclick на самой кнопке или в функции чтото поменять?

рони 17.12.2017 10:12

3dartmax,
:-? присвойте клик каждой кнопке, вместо клика по контейнеру, если вам нужно.

3dartmax 17.12.2017 15:51

<button class="btn red act" onclick="myFunc">Red</button>
<button class="btn yellow" onclick="myFunc">Yellow</button>
<button class="btn green" onclick="myFunc">Green</button>
<button class="btn blue" onclick="myFunc">Blue</button>


только функция будет не "function(el, i)" а - "function myFunc(el, i)"
верно?

рони 17.12.2017 16:03

Цитата:

Сообщение от 3dartmax
верно?

:-? не знаю, о чём вы

3dartmax 18.12.2017 02:29

"присвойте клик каждой кнопке" - это надо сделать в js файле?

рони 18.12.2017 09:57

Цитата:

Сообщение от 3dartmax
это надо сделать в js файле?

да, вместо одной строки 91 пост №15 будет 4
типа a[0].addEventListener("click", function(event)
a[1].addEventListener("click", function(event) или циклом тоже самое

3dartmax 18.12.2017 16:36

a[0].addEventListener("click", function(event) {...});
a[1].addEventListener("click", function(event) {...});
a[2].addEventListener("click", function(event) {...});
a[3].addEventListener("click", function(event) {...});

Так?

рони 18.12.2017 16:55

3dartmax,
да


Часовой пояс GMT +3, время: 09:30.