Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Изменить поведение кнопки по клику (https://javascript.ru/forum/dom-window/69553-izmenit-povedenie-knopki-po-kliku.html)

dupre 03.07.2017 05:33

Изменить поведение кнопки по клику
 
Есть фрагмент связки кода:
Код:

html
<div id="mySidenav" class="sidenav">
  <a href="javascript:void(0)" class="closebtn" onclick="closeNav()">&times;</a>
  <a href="#">About</a>
  <a href="#">Services</a>
  <a href="#">Clients</a>
  <a href="#">Contact</a>
</div>


css
.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 {
    transition: margin-left .5s;
    padding: 16px;
    width: 800px;
}


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";
}
</div>


Оригинал и пример кода здесь — https://www.w3schools.com/howto/tryi...s_sidenav_push

В данном примере sidenav открывается по одной кнопке, закрывается по другой. Собственно вопрос: как из двух кнопок сделать одну?, чтобы поведение элемента зависело только от одной кнопки, + закрытие sidenav чтоб работало при клике, как по самой кнопке, так и по клику в любом месте окна, кроме самого sidenav.

Начал изучать js не давно, хочется увидеть и понять, как это может быть реализовано на чистом js.

рони 03.07.2017 09:31

Цитата:

Сообщение от dupre
закрытие sidenav чтоб работало при клике, как по самой кнопке, так и по клику в любом месте окна,


https://javascript.ru/forum/misc/69479-zakryt-modalnoe-okno-klikom-vokrug.html#post456597

рони 03.07.2017 10:10

меню слева и закрытие по клику в любом месте окна
 
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" >&times;</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">&#9776; 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>

dupre 06.07.2017 05:53

: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. Так ли это?

рони 06.07.2017 08:08

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">&#9776; 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>

dupre 07.07.2017 03:38

Рони, спасибо!
Постараюсь понять данный код и поэкспериментировать с ним, ведь хочется уметь это и самому.

dupre 27.07.2017 01:14

рони, приветствую! Взялся сделать так, чтобы элемент
<span class="openclosebtn">☰ open</span>
при скроле страницы, в случае появления полосы прокрутки при заполнении страницы контентом оставался на месте (fixed), но вместе с тем, при клике, чтобы вёл себя как <main> и его содержимое, то есть по клику смещался в право и по клику возвращался на место. У меня ничего не выходит, не понимаю, как это сделать. Эксперименты по наитию ничего не дали.

P.s. Данную реализацию рассматриваю с кодом который здесь: "меню слева и закрытие по клику в любом месте окна"

рони 27.07.2017 07:59

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" >&times;</a>
  <a href="#">About</a>
  <a href="#">Services</a>
  <a href="#">Clients</a>
  <a href="#">Contact</a>
</div>

<div id="main">
  <span class="openclosebtn">&#9776; 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>

dupre 27.07.2017 11:09

На первый взгляд, да. Но содержимое <main> в этом случае замирает на месте и страница не скролится...

рони 27.07.2017 11:30

Цитата:

Сообщение от dupre
Но содержимое <main>

оставьте только кнопку в фиксированном блоке, остальное перенесите.

dupre 27.07.2017 12:46

Ронни, возможно я криво спросил, чего хотелось бы достичь. Здесь -
http://varunmalhotra.xyz/blog/ - наглядный пример искомого поведения всех элементов страницы при клике на кнопку меню, именно такая реализация имелась в виду...

рони 27.07.2017 13:07

скрытое меню слева
 
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" >&times;</a>
  <a href="#">About</a>
  <a href="#">Services</a>
  <a href="#">Clients</a>
  <a href="#">Contact</a>
</div>

<div id="main">
  <span class="openclosebtn">&#9776;</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 28.07.2017 12:05

Рони, добрый день! Как вариант, хотелось увидеть и понять и такую реализация задачи. Более того, здесь можно играть с разными вариантами представленного тобой кода и, конечно, так проще будет понять разницу в вариантах исполнения. Спасибки за поддержку!

рони 28.07.2017 12:13

dupre,
пожалуйста, но я не понял, что вы написали. :)

dupre 29.07.2017 12:31

Рони, имелось в виду, что вы представили несколько вариантов исполнения по сути одной задачи — это интересно и очень познавательно, ведь появляется выбор. Например, можно взять:
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: Спасибо !

dupre 09.08.2017 19:26

рони, добрый вечер! По клику
<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');
	    });
	});
});

Вполне ли хорош код для реализации данной задачи, или здесь было бы уместней написать его, как либо иначе?

рони 09.08.2017 19:34

dupre,
сделайте полный макет, а пока в строке 2 ... всплывая клики будут множить animate, отсюда и
Цитата:

Сообщение от dupre
несколько движений вправо-влево


рони 09.08.2017 20:05

dupre,
может поможет
function(event) {event.stopPropagation();

dupre 09.08.2017 21:05

рони, макет тот же, что разбирали в прошлый раз, а применить хотел к
<span class="openclosebtn">☰</span>

dupre 09.08.2017 21:20

Изначальный код здесь http://jsfiddle.net/eo7okLdy/. Просто пробовал переделать всё по своему, но не получилось.

рони 09.08.2017 21:45

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" >&times;</a>
  <a href="#">About</a>
  <a href="#">Services</a>
  <a href="#">Clients</a>
  <a href="#">Contact</a>
</div>

<div id="main">
  <span class="openclosebtn">&#9776;</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>

dupre 10.08.2017 03:36

рони,
извини, пожалуйста, за мои вечно кривые вопросы. Старательно, попробую спросить более кратко: чтобы
<span class="openclosebtn">☰</span>
при открытии сайдбара
<div id="mySidenav" class="sidenav">
  <a href="#" class="closebtn" >&times;</a>
  <a href="#">About</a>
  <a href="#">Services</a>
  <a href="#">Clients</a>
  <a href="#">Contact</a>
</div>

с помощью анимации сместился влево и остановился сверху на пунктами меню открывшегося сайдбара, и после закрытия сайдбара, так же, анимированно вернулся на прежнее место.
Закрывающий крестик, что на территории сайдбара уже, тогда, конечно не будет нужен и его просто можно удалить или закоментировать.
Ранее не приходилось видеть подобной реализации. Кажется, это будет необычно, интересно и очень красиво.

рони 10.08.2017 08:10

Цитата:

Сообщение от dupre
попробую спросить

не понял

Dilettante_Pro 10.08.2017 10:14

dupre,
Цитата:

Сообщение от dupre
с помощью анимации сместился влево и остановился сверху на пунктами меню открывшегося сайдбара

В примере рони он изначально стоит слева вверху - откуда и куда ему смещаться?
Может, его просто оставлять на месте, а сайдбар открывать под ним?
Крестик же просто убрать из сайдбара.

dupre 10.08.2017 15:28

Сделал скрин, взгляните — https://yadi.sk/i/a1AJDQsX3Lsq4j

dupre 10.08.2017 15:36

рони, сделал скрин, с ним наверное уже нагляднее будет. Дублирую ссылку https://yadi.sk/i/a1AJDQsX3Lsq4j

рони 10.08.2017 16:48

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>

Dilettante_Pro 10.08.2017 16:53

Вариант
<!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>

dupre 10.08.2017 19:12

рони,
а, если попробовать без анимации. То есть:
1.над списком в html физически прописать дубликат
<span class="openclosebtn">☰</span>
в css задав ему 100% прозрачности

2. а при открытии сайдбара, задать ему цвет, следовательно он станет видимым

3. а основной "openclosebtn", при помощи которого мы открывает сайдбар, при этом примет 100% прозрачность и станет видимым лишь если закроется сайдбар


P.s Вариант с анимацией буду искать, если найду выложу сюда, глянуть для интереса просто.

dupre 10.08.2017 19:20

Dilettante_Pro, спасибо за помощь!
Имеющиеся варианты реализации не совсем то, что ищется. Скинул сообщение на имя Рони, с иной идеей, глянь пожалуйста.

Dilettante_Pro 11.08.2017 10:34

<!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>

dupre 12.08.2017 15:49

Dilettante_Pro,
да, можно сказать почти что искалось. Маленько подогнать под свои нужды и будет, что надо. Своими силами тоже постараюсь что-нибудь сделать, результат выложу, просто глянуть, что выйдет. Спасибки большие и рони и тебе за подмогу!

j0hnik 15.08.2017 04:48

squrell,
добавь в <script>
$(function(){
$('.igrouplist a').mouseenter(function(){
		top.location = this.href;
	});
});

dupre 20.08.2017 16:10

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;
    });
});

Добавленное не работает. Я криво добавил?

j0hnik 20.08.2017 19:42

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;
			};
		});
	});


вот так сделай

dupre 24.08.2017 22:41

j0hnik,
сделал, но у меня не работает. Изменений не увидел, как было всё, так и осталось..

j0hnik 24.08.2017 23:32

Цитата:

Сообщение от dupre (Сообщение 462630)
j0hnik,
сделал, но у меня не работает. Изменений не увидел, как было всё, так и осталось..

Я сейчас тему перечитал и не пойму как тут мой пост оказался, тот человек которому я этот код писал хотел чтобы при наведении его по ссылке перебрасывало, а потом ты сказал, что не работает и я на автомате переписал без jquery.
Убери этот кусок в общем.

dupre 27.08.2017 02:28

j0hnik,
подмогни с моим вопросом, не разобраться мне самому.

j0hnik 27.08.2017 05:59

Цитата:

Сообщение от dupre (Сообщение 462817)
j0hnik,
подмогни с моим вопросом, не разобраться мне самому.

Чем помочь-то
Рони вам уже столько вариантов накидал, из них есть примеры что проще не придумаешь.
возьмите какой нравится и пользуйтесь.
тот можете еще глянуть, но они более сложные будут.
https://sitesforprofit.com/incredibl...-menu-patterns

dupre 05.09.2017 05:51

рони, приветствую! Создал тему на основе твоего кода, продолжаю с ним эксперименты , глянь пожалуйста по возможнсти. Лежит здесь — http://javascript.ru/forum/site/7043...-po-kliku.html затемнение фона по клику.


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