Изменить поведение кнопки по клику
Есть фрагмент связки кода:
Код:
html Оригинал и пример кода здесь — https://www.w3schools.com/howto/tryi...s_sidenav_push В данном примере sidenav открывается по одной кнопке, закрывается по другой. Собственно вопрос: как из двух кнопок сделать одну?, чтобы поведение элемента зависело только от одной кнопки, + закрытие sidenav чтоб работало при клике, как по самой кнопке, так и по клику в любом месте окна, кроме самого sidenav. Начал изучать js не давно, хочется увидеть и понять, как это может быть реализовано на чистом js. |
Цитата:
https://javascript.ru/forum/misc/69479-zakryt-modalnoe-okno-klikom-vokrug.html#post456597 |
меню слева и закрытие по клику в любом месте окна
dupre,
<!DOCTYPE html> <html> <head> <style> body { font-family: "Lato", sans-serif; position: relative; } .sidenav { height: 100%; width: 0; position: fixed; z-index: 1; top: 0; left: 0; background-color: #111; overflow-x: hidden; transition: 0.5s; padding-top: 60px; } .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s; } .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } .sidenav .closebtn { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; } #main { position: absolute; left: 0px; transition: left .5s; padding: 16px; } @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } .sidenav.open { width: 250px } .sidenav.open ~ #main{ left:250px; } .openclosebtn{ font-size:30px;cursor:pointer } </style> </head> <body> <div id="mySidenav" class="sidenav"> <a href="#" class="closebtn" >×</a> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> <div id="main"> <h2>Sidenav Push Example</h2> <p>Click on the element below to open the side navigation menu, and push this content to the right.</p> <span class="openclosebtn">☰ open</span> </div> <script src="https://cdn.polyfill.io/v1/polyfill.js?Element.prototype.closest"></script> <script> window.addEventListener('DOMContentLoaded', function() { var sidenav = document.querySelector('.sidenav'); document.addEventListener("click", function(event){ var target = event.target; if( target.closest(".sidenav") && !target.closest(".closebtn")) return; else if(target.closest(".openclosebtn")) {event.preventDefault(); sidenav.classList.toggle("open")} else sidenav.classList.remove("open"); }); }); </script> </body> </html> |
:stop: — эмоция на слишком крученный код для новичка в js )
Рони, спасибки, за не оставленный без внимания вопрос. Как новичку в изучении js, было бы понятней, если бы код был написан проще. Признаться, я рассчитывал увидеть небольшие изменения в коде оригинала: function openNav() { document.getElementById("mySidenav").style.width = "250px"; document.getElementById("main").style.marginLeft = "250px"; } function closeNav() { document.getElementById("mySidenav").style.width = "0"; document.getElementById("main").style.marginLeft= "0"; } Такая запись, учитывая мои нулевые на сегодняшний день познания, как-то более понятна. Пытаясь разобраться в вопросе, рассчитывал закрывающий крестик удалить вовсе и оставить для закрытия-открытия элемента лишь иконку-бургер. Возможно ли так модифицировать код оригинала? P.s. Если я правильно понимаю, код с оригинала есть классический синтаксис js. Так ли это? |
dupre,
<!DOCTYPE html> <html> <head> <style> body { font-family: "Lato", sans-serif; position: relative; } .sidenav { height: 100%; width: 0; position: fixed; z-index: 1; top: 0; left: 0; background-color: #111; overflow-x: hidden; transition: 0.5s; padding-top: 60px; } .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s; } .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } .sidenav .closebtn { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; } #main { position: absolute; left: 0px; transition: left .5s; padding: 16px; } @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } .sidenav.open { width: 250px } .sidenav.open ~ #main{ left:250px; } .openclosebtn{ font-size:30px;cursor:pointer } </style> </head> <body> <div id="mySidenav" class="sidenav"> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> <div id="main"> <h2>Sidenav Push Example</h2> <p>Click on the element below to open the side navigation menu, and push this content to the right.</p> <span class="openclosebtn">☰ open</span> </div> <script> window.addEventListener('DOMContentLoaded', function() { var sidenav = document.querySelector('.sidenav'); var openclosebtn = document.querySelector('.openclosebtn'); openclosebtn.addEventListener("click", function(event){ sidenav.classList.toggle("open")}) }); </script> </body> </html> |
Рони, спасибо!
Постараюсь понять данный код и поэкспериментировать с ним, ведь хочется уметь это и самому. |
рони, приветствую! Взялся сделать так, чтобы элемент
<span class="openclosebtn">☰ open</span>при скроле страницы, в случае появления полосы прокрутки при заполнении страницы контентом оставался на месте (fixed), но вместе с тем, при клике, чтобы вёл себя как <main> и его содержимое, то есть по клику смещался в право и по клику возвращался на место. У меня ничего не выходит, не понимаю, как это сделать. Эксперименты по наитию ничего не дали. P.s. Данную реализацию рассматриваю с кодом который здесь: "меню слева и закрытие по клику в любом месте окна" |
dupre,
строка 46 :-? fixed вроде никаких проблем ? <!DOCTYPE html> <html> <head> <style> body { font-family: "Lato", sans-serif; position: relative; height: 1700px; } .sidenav { height: 100%; width: 0; position: fixed; z-index: 1; top: 0; left: 0; background-color: #111; overflow-x: hidden; transition: 0.5s; padding-top: 60px; } .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s; } .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } .sidenav .closebtn { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; } #main { position: fixed; left: 0px; transition: left .5s; padding: 16px; } @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } .sidenav.open { width: 250px } .sidenav.open ~ #main{ left:250px; } .openclosebtn{ font-size:30px;cursor:pointer } h1{ margin: 0 auto; text-align: center; } </style> </head> <body> <div id="mySidenav" class="sidenav"> <a href="#" class="closebtn" >×</a> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> <div id="main"> <span class="openclosebtn">☰ open</span> </div> <h1>test</h1> <script src="https://cdn.polyfill.io/v1/polyfill.js?Element.prototype.closest"></script> <script> window.addEventListener('DOMContentLoaded', function() { var sidenav = document.querySelector('.sidenav'); document.addEventListener("click", function(event){ var target = event.target; if( target.closest(".sidenav") && !target.closest(".closebtn")) return; else if(target.closest(".openclosebtn")) {event.preventDefault(); sidenav.classList.toggle("open")} else sidenav.classList.remove("open"); }); }); </script> </body> </html> |
На первый взгляд, да. Но содержимое <main> в этом случае замирает на месте и страница не скролится...
|
Цитата:
|
Ронни, возможно я криво спросил, чего хотелось бы достичь. Здесь -
http://varunmalhotra.xyz/blog/ - наглядный пример искомого поведения всех элементов страницы при клике на кнопку меню, именно такая реализация имелась в виду... |
скрытое меню слева
dupre,
<!DOCTYPE html> <html> <head> <style> body { font-family: "Lato", sans-serif; position: relative; height: 1700px; transition: all 0.3s; } .sidenav { height: 100%; width: 0; position: fixed; z-index: 1; top: 0; left: 0; background-color: #111; overflow-x: hidden; transition: 0.5s; padding-top: 60px; } .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s; } .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } .sidenav .closebtn { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; } #main { position: fixed; left: 0px; transition: left .5s; padding: 4px 2px; width: 36px; height: 36px; background-color: #000000; text-align: center; margin-left: 8px; line-height: 36px; } @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } body.open{ margin-left: 250px; } body.open .sidenav{ width: 250px } body.open #main{ left:250px; } .openclosebtn{ font-size:30px;cursor:pointer; color: #FFFFFF; } h1{ margin: 0 auto; text-align: center; } </style> </head> <body> <div id="mySidenav" class="sidenav"> <a href="#" class="closebtn" >×</a> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> <div id="main"> <span class="openclosebtn">☰</span> </div> <h1>test</h1> <script src="https://cdn.polyfill.io/v1/polyfill.js?Element.prototype.closest"></script> <script> window.addEventListener('DOMContentLoaded', function() { var body = document.querySelector('body'); document.addEventListener("click", function(event){ var target = event.target; if( target.closest(".sidenav") && !target.closest(".closebtn")) return; else if(target.closest("#main")) {event.preventDefault(); body.classList.toggle("open")} else body.classList.remove("open"); }); }); </script> </body> </html> |
Рони, добрый день! Как вариант, хотелось увидеть и понять и такую реализация задачи. Более того, здесь можно играть с разными вариантами представленного тобой кода и, конечно, так проще будет понять разницу в вариантах исполнения. Спасибки за поддержку!
|
dupre,
пожалуйста, но я не понял, что вы написали. :) |
Рони, имелось в виду, что вы представили несколько вариантов исполнения по сути одной задачи — это интересно и очень познавательно, ведь появляется выбор. Например, можно взять:
window.addEventListener('DOMContentLoaded', function() { var body = document.querySelector('body'); document.addEventListener("click", function(event){ var target = event.target; if( target.closest(".sidenav") && !target.closest(".closebtn")) return; else if(target.closest("#main")) {event.preventDefault(); body.classList.toggle("open")} else body.classList.remove("open"); }); }); сравнить например с: window.addEventListener('DOMContentLoaded', function() { var sidenav = document.querySelector('.sidenav'); document.addEventListener("click", function(event){ var target = event.target; if( target.closest(".sidenav") && !target.closest(".closebtn")) return; else if(target.closest(".openclosebtn")) {event.preventDefault(); sidenav.classList.toggle("open")} else sidenav.classList.remove("open"); }); }); и, если присмотреться разница очевидна. Например, строки 2 и 6. И это круто просто :dance: Спасибо ! |
рони, добрый вечер! По клику
<div class="phone-keys">1</div>сдвигается влево и по клику возвращается в исходное положение. Возвращаясь в исходное положение div, прежде, чем остановиться, делает несколько движений вправо-влево. Как сделать так, чтобы при возврате в исходное положение div останавливался сразу же, без лишних движений? Код css: .phone-keys{width: 100px;height: 100px;float: left;background: gray; border: 1px solid yellow;margin-left: 150px;} Код js: $(document).ready(function(){ $('*').on('click', function(){ $('.moved').animate({'left':'0'}, 500, function(){ $(this).removeClass('moved'); }); }); $(".phone-keys").not('.moved').on('click', function(){ $(this).css('position', 'relative').animate({'left':'-50px'}, 500, function(){ $(this).addClass('moved'); }); }); }); Вполне ли хорош код для реализации данной задачи, или здесь было бы уместней написать его, как либо иначе? |
dupre,
сделайте полный макет, а пока в строке 2 ... всплывая клики будут множить animate, отсюда и Цитата:
|
dupre,
может поможет function(event) {event.stopPropagation(); |
рони, макет тот же, что разбирали в прошлый раз, а применить хотел к
<span class="openclosebtn">☰</span> |
Изначальный код здесь http://jsfiddle.net/eo7okLdy/. Просто пробовал переделать всё по своему, но не получилось.
|
dupre,
<!DOCTYPE html> <html> <head> <style> body { font-family: "Lato", sans-serif; position: relative; height: 1700px; transition: all 0.3s; } .sidenav { height: 100%; width: 0; position: fixed; z-index: 1; top: 0; left: 0; background-color: #111; overflow-x: hidden; transition: 0.5s; padding-top: 60px; } .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s; } .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } .sidenav .closebtn { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; } #main { position: fixed; left: 0px; transition: left .5s; padding: 4px 2px; width: 36px; height: 36px; background-color: #000000; text-align: center; margin-left: 8px; line-height: 36px; } @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } .openclosebtn{ font-size:30px;cursor:pointer; color: #FFFFFF; } h1{ margin: 0 auto; text-align: center; } </style> </head> <body> <div id="mySidenav" class="sidenav"> <a href="#" class="closebtn" >×</a> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> <div id="main"> <span class="openclosebtn">☰</span> </div> <h1>test</h1> <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> <script> $(function() { var a = 0; $(".openclosebtn").on("click", function(b) { b.stopPropagation(); a ^= 1; $(".sidenav").stop().animate({ width: 250 * a }, 500); $("#main").stop().animate({ left: 250 * a }, 500); $("body").stop().animate({ "margin-left": 250 * a + "px" }, 500) }); $(document).on("click", function(b) { !a || !$(b.target).closest(".closebtn").length && $(b.target).closest(".sidenav").length || $(".openclosebtn").click() }) }); </script> </body> </html> |
рони,
извини, пожалуйста, за мои вечно кривые вопросы. Старательно, попробую спросить более кратко: чтобы <span class="openclosebtn">☰</span>при открытии сайдбара <div id="mySidenav" class="sidenav"> <a href="#" class="closebtn" >×</a> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> с помощью анимации сместился влево и остановился сверху на пунктами меню открывшегося сайдбара, и после закрытия сайдбара, так же, анимированно вернулся на прежнее место. Закрывающий крестик, что на территории сайдбара уже, тогда, конечно не будет нужен и его просто можно удалить или закоментировать. Ранее не приходилось видеть подобной реализации. Кажется, это будет необычно, интересно и очень красиво. |
Цитата:
|
dupre,
Цитата:
Может, его просто оставлять на месте, а сайдбар открывать под ним? Крестик же просто убрать из сайдбара. |
Сделал скрин, взгляните — https://yadi.sk/i/a1AJDQsX3Lsq4j
|
рони, сделал скрин, с ним наверное уже нагляднее будет. Дублирую ссылку https://yadi.sk/i/a1AJDQsX3Lsq4j
|
dupre,
далее лучше к сециалистам по css ... <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <style> body { font-family: "Lato", sans-serif; position: relative; height: 1700px; transition: all 0.3s; } .sidenav { height: 100%; width: 0; position: fixed; top: 40px; left: 0; background-color: #111; overflow-x: hidden; transition: 0.5s; padding-top: 60px; } .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s; } .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } .sidenav .closebtn { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; } #main { z-index: 1; position: fixed; top: 0; left: 0; color: #FFFFFF; background-color: #000000; text-align: left; width: 250px; height: 50px; } @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } .openclosebtn{ line-height: 36px; background-color: #000000; width: 36px; height: 36px; font-size:30px;cursor:pointer; color: #FFFFFF; } h1{ margin: 0 auto; text-align: center; } </style> </head> <body> <div id="mySidenav" class="sidenav"> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> <div id="main"> <span class="openclosebtn">☰</span> меню сайта </div> <h1>test</h1> <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> <script> $(function() { var a = 0; $(".openclosebtn").on("click", function(b) { b.stopPropagation(); a ^= 1; $(".sidenav").stop().animate({ width: 250 * a }, 500); $("body").stop().animate({ "margin-left": 250 * a + "px" }, 500) }); $(document).on("click", function(b) { !a || !$(b.target).closest(".closebtn").length && $(b.target).closest(".sidenav").length || $(".openclosebtn").click() }) }); </script> </body> </html> |
Вариант
<!DOCTYPE html> <html> <head> <style> body { font-family: "Lato", sans-serif; position: relative; height: 1700px; transition: all 0.3s; } .sidenav { height: 100%; width: 0; position: fixed; z-index: 1; top: 36px; left: 0; background-color: #111; overflow-x: hidden; transition: 0.5s; padding-top: 60px; } .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s; } .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } #main { position: fixed; top:0px; left: 300px; transition: left .5s; padding: 4px 2px; width: 245px; height: 36px; background-color: #000000; margin-left: 1px; line-height: 36px; } @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } .openclosebtn{ font-size:30px;cursor:pointer; color: #FFFFFF; } h1{ margin: 0 auto; text-align: left; } </style> </head> <body> <div id="mySidenav" class="sidenav"> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> <div id="main"> <span class="openclosebtn">☰ Меню сайта</span> </div> <h1>test</h1> <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> <script> $(function() { var a = 0, b; $(".openclosebtn").on("click", function(b) { b.stopPropagation(); b = a; a ^= 1; $(".sidenav").stop().animate({ width: 250 * a }, 500); $("#main").stop().animate({ left: 300 * b }, 500); $("body").stop().animate({ "margin-left": 250 * a + "px" }, 500) }); $(document).on("click", function(b) { !a || !$(b.target).closest(".closebtn").length && $(b.target).closest(".sidenav").length || $(".openclosebtn").click() }) }); </script> </body> </html> |
рони,
а, если попробовать без анимации. То есть: 1.над списком в html физически прописать дубликат <span class="openclosebtn">☰</span>в css задав ему 100% прозрачности 2. а при открытии сайдбара, задать ему цвет, следовательно он станет видимым 3. а основной "openclosebtn", при помощи которого мы открывает сайдбар, при этом примет 100% прозрачность и станет видимым лишь если закроется сайдбар P.s Вариант с анимацией буду искать, если найду выложу сюда, глянуть для интереса просто. |
Dilettante_Pro, спасибо за помощь!
Имеющиеся варианты реализации не совсем то, что ищется. Скинул сообщение на имя Рони, с иной идеей, глянь пожалуйста. |
<!DOCTYPE html> <html> <head> <style> body { font-family: "Lato", sans-serif; position: relative; height: 1700px; transition: all 0.3s; } .sidenav { height: 100%; width: 0; position: fixed; z-index: 1; top: 36px; left: 0; background-color: #111; overflow-x: hidden; transition: 0.5s; padding-top: 60px; } .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s; } .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } #main { position: fixed; top:0px; left: 300px; transition: opacity .5s ease-in; opacity: 1; padding: 4px 2px; width: 245px; height: 36px; background-color: #000000; margin-left: 1px; line-height: 36px; } #main0 { position: fixed; top:0px; left: 0px; transition: opacity .5s ease-in; opacity: 0; padding: 4px 2px; width: 245px; height: 36px; background-color: #000000; margin-left: 1px; line-height: 36px; } @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } .openclosebtn{ font-size:30px;cursor:pointer; color: #FFFFFF; } h1{ margin: 0 auto; text-align: left; } </style> </head> <body> <div id="mySidenav" class="sidenav"> <a href="#">About</a> <a href="#">Services</a> <a href="#">Clients</a> <a href="#">Contact</a> </div> <div id="main0"> <span class="openclosebtn">☰ Меню сайта</span> </div> <div id="main"> <span class="openclosebtn">☰ Меню сайта</span> </div> <h1>test</h1> <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> <script> $(function() { var a = 0, b; $(".openclosebtn").on("click", function(b) { b.stopPropagation(); b = a; a ^= 1; $(".sidenav").stop().animate({ width: 250 * a }, 500); $("#main").stop().animate({ opacity: 1 * b }, 500); $("#main0").stop().animate({ opacity: 1 * a }, 500); $("body").stop().animate({ "margin-left": 250 * a + "px" }, 500) }); }); </script> </body> </html> |
Dilettante_Pro,
да, можно сказать почти что искалось. Маленько подогнать под свои нужды и будет, что надо. Своими силами тоже постараюсь что-нибудь сделать, результат выложу, просто глянуть, что выйдет. Спасибки большие и рони и тебе за подмогу! |
squrell,
добавь в <script> $(function(){ $('.igrouplist a').mouseenter(function(){ top.location = this.href; }); }); |
j0hnik,
весь js во внешнем файле. Было так: window.addEventListener('DOMContentLoaded', function() { var body = document.querySelector('body'); document.addEventListener("click", function(event) { var target = event.target; if (target.closest(".sidenav") && !target.closest(".closebtn")) return; else if (target.closest("#main")) { event.preventDefault(); body.classList.toggle("open") } else body.classList.remove("open"); }); }); добавил, стало так: window.addEventListener('DOMContentLoaded', function() { var body = document.querySelector('body'); document.addEventListener("click", function(event) { var target = event.target; if (target.closest(".sidenav") && !target.closest(".closebtn")) return; else if (target.closest("#main")) { event.preventDefault(); body.classList.toggle("open") } else body.classList.remove("open"); }); }); $(function(){ $('.igrouplist a').mouseenter(function(){ top.location = this.href; }); }); Добавленное не работает. Я криво добавил? |
window.addEventListener('DOMContentLoaded', function() { var body = document.querySelector('body'); document.addEventListener("click", function(event) { var target = event.target; if (target.closest(".sidenav") && !target.closest(".closebtn")) return; else if (target.closest("#main")) { event.preventDefault(); body.classList.toggle("open") } else body.classList.remove("open"); }); [].forEach.call(document.querySelectorAll('.igrouplist a'), function(el){ el.onmouseenter=function(){ top.location = this.href; }; }); }); вот так сделай |
j0hnik,
сделал, но у меня не работает. Изменений не увидел, как было всё, так и осталось.. |
Цитата:
Убери этот кусок в общем. |
j0hnik,
подмогни с моим вопросом, не разобраться мне самому. |
Цитата:
Рони вам уже столько вариантов накидал, из них есть примеры что проще не придумаешь. возьмите какой нравится и пользуйтесь. тот можете еще глянуть, но они более сложные будут. https://sitesforprofit.com/incredibl...-menu-patterns |
рони, приветствую! Создал тему на основе твоего кода, продолжаю с ним эксперименты , глянь пожалуйста по возможнсти. Лежит здесь — http://javascript.ru/forum/site/7043...-po-kliku.html затемнение фона по клику.
|
Часовой пояс GMT +3, время: 23:21. |