Как закрыть боковую панель в мобильном представлении, когда пользователь выполняет событие «прокрутка», «касание» или «нажатие» - PullRequest
1 голос
/ 06 июля 2019

Я пытаюсь разработать сайт, который содержит боковую панель, панель навигации и тело. Это отзывчивый сайт. В мобильном представлении, когда пользователь нажимает на значок гамбургера, открывается боковая панель, поэтому я хотел закрыть ее после того, как пользователь выполнит какое-либо событие «Касание» для элемента, кроме боковой панели, т.е. на панели тела.

Код боковой панели:

<div id="sidebar-nav" class="sidebar">
    <div class="sidebar-scroll">
        <nav>
            <ul class="nav">
                <li> Sidebar element </li>                
            </ul>
        </nav>
    </div>
</div>

код Навбара:

<nav class="navbar navbar-default navbar-fixed-top">
    <div class="brand">
    </div>
    <div class="container-fluid">
        <div class="navbar-btn">
            <button type="button" class="btn-toggle-fullwidth"><i class="fa fa-bars"></i></button>
        </div>
</nav>

Код панели кузова:

<html lang="en">
    <head>
    </head>
    <body>
        <div id="wrapper">
            <div class="main">
                <div class = "article_view"> 
                    <!-- this is the body panel -->
                </div>
            </div>
        </div>
    </body>
</html>

Обратите внимание, что я сделал для события click. Это работает правильно.

$(".article_view").click(function(e) {
    if ($("body").hasClass("layout-fullwidth offcanvas-active")) {
         $("body").removeClass("layout-fullwidth offcanvas-active");
           $("body").toggleClass("undefined")
    }
})

Например:

Откройте youtube.com в мобильном представлении, откройте боковую панель и выполните события на теле, такие как касание или пролистывание. Боковая панель автоматически закроется. (Я хотел сделать так)

Откройте stackoverflow.com's боковую панель и выполните те же события, что и проведением пальцем или касанием. Боковая панель не закроется.

Пожалуйста, дайте мне знать, как обрабатывать сенсорные события в мобильном представлении (проведите пальцем влево, проведите пальцем вниз, проведите вправо или коснитесь).

Ответы [ 3 ]

1 голос
/ 06 июля 2019

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

Событие onClose срабатывает при щелчке или касании пользователем наложения, поэтому событие OnScroll не требуется, наложение не прокручивается

function overlay(isShow){
  var elm = document.getElementById('overlay')
  if (isShow) {
    elm.style.display = 'block';
  } else {
    elm.style.display = 'none';
  }
}

function openNav() {
  overlay(true);
	document.getElementById('mySidenav').style.width="250px";
}

function closeNav() {
  overlay(false);
	document.getElementById('mySidenav').style.width="0"
}
	.sidenav {
		height: 100%;
		width: 0;
		position: fixed;
		z-index: 3;
		top: 0;
		right: 0;
		overflow-x: hidden;
		transition: 0.5s;
		padding-top: 60px;
		background-color: #111;
	}

	.sidenav a{

		display: block;
		padding: 8px 8px 8px 32px;
		text-decoration: none;
		font-size: 25px;
		color: #818181;
		transition: 0.3s;
	}
	
	.sidenav a:hover{

		color: #F1F1F1;

	} 

	.sidenav .closebtn{
		
		position: absolute;
		top: 0;
		right: 25px;
		font-size: 35px;
		margin-left: 50px;
	}
  
  #overlay{
    z-index: 2;
    position: fixed;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    display: none;
  }

	@media screen and (max-height: 450px){

		.sidenav{padding-top: 15px;}
		.sidenav a{font-size: 18px;}

	}
<div id="mySidenav" class="sidenav">
	<a href="javascript:void(0)" class="closebtn" onclick="closeNav()">&times;</a>
	<a href="#">Menu 1</a>
	<a href="#">Menu 2</a>
</div>
<h2>Animated Sidenav</h2>
<p>Click on the element below to open sidenav</p>
<span style="cursor: pointer;" onclick="openNav()">Menu</span>
<div id="overlay" onclick="closeNav()" ontouchstart="closeNav()" onscroll="closeNav()"></div>
0 голосов
/ 06 июля 2019

Это ваше решение

document.getElementById('main').addEventListener('click', closeNav);

function openNav() {
  document.getElementById("mySidenav").style.width = "230px";
  document.getElementById("main").style.marginLeft = "250px";
}

/* Set the width of the side navigation to 0 and the left margin of the page content to 0 */
function closeNav() {
  document.getElementById("mySidenav").style.width = "0";
  document.getElementById("main").style.marginLeft = "0";
}
/* The side navigation menu */

.sidenav {
  height: 100%;
  /* 100% Full-height */
  width: 0;
  /* 0 width - change this with JavaScript */
  position: fixed;
  /* Stay in place */
  z-index: 1;
  /* Stay on top */
  top: 0;
  left: 0;
  background-color: #111;
  /* Black*/
  overflow-x: hidden;
  /* Disable horizontal scroll */
  padding-top: 60px;
  /* Place content 60px from the top */
  transition: 0.5s;
  /* 0.5 second transition effect to slide in the sidenav */
}


/* The navigation menu links */

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


/* When you mouse over the navigation links, change their color */

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


/* Position and style the close button (top right corner) */

.sidenav .closebtn {
  position: absolute;
  top: 0;
  right: 25px;
  font-size: 36px;
  margin-left: 50px;
}


/* Style page content - use this if you want to push the page content to the right when you open the side navigation */

#main {
  transition: margin-left .5s;
  padding: 20px;
}


/* On smaller screens, where height is less than 450px, change the style of the sidenav (less padding and a smaller font size) */

@media screen and (max-height: 450px) {
  .sidenav {
    padding-top: 15px;
  }
  .sidenav a {
    font-size: 18px;
  }
}
<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>

<!-- Use any element to open the sidenav -->
<span onclick="openNav()">Siderbar Button click here</span>

<div id="main" style="height:100vh;">
  Body content is here
</div>
0 голосов
/ 06 июля 2019

Прежде всего, пожалуйста, рассмотрите возможность предоставления дополнительной информации, например, какие у вас компоненты.Вы также можете включить демонстрационный фрагмент, показывающий работу вашей оболочки.Помимо этого у меня может быть решение.Вы можете просто изменить привязку своего события следующим образом, и она должна работать (это предполагает, что у ваших основных пользователей нет гибридных мобильных телефонов, таких как некоторые blackberrys)

 $(".article_view").on("touchstart click", function(e) {
     if ($("body").hasClass("layout-fullwidth offcanvas-active")) {
        $("body").removeClass("layout-fullwidth offcanvas-active");
        $("body").toggleClass("undefined")
     }
 });
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...