- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用 Javascript 中的切换创建响应式导航栏。向下滚动 70vh 后出现导航栏。在最大宽度为 768 像素时,响应能力开始发挥作用,单击时会出现带有下拉菜单的汉堡。
在 Chrome 和 Firefox 中一切正常——当手动调整浏览器的大小和使用浏览器的移动设备模拟器时。但在 Safari 和实际移动设备(iPad、iPhone 7、iPhone 5)中,导航栏与汉堡一起出现,当我单击汉堡时,它会按预期转换为“X”,但下拉菜单不会出现。
编辑澄清:如果您查看下面的代码片段,这就是应该发生的情况。这在 Chrome 和 Firefox 中确实会发生,但在实际的移动设备上不会。相反,在移动设备上,当我按下汉堡时,它会变成一个“X”,但下拉菜单不会滑到屏幕上。
我花了一天多的时间试图弄清楚发生了什么。我的 HTML head 具有适合移动设备宽度的元标记,并且我已尝试为 CSS 中的每个动画、变换、过渡和关键帧使用适当的 -moz、-webkit、-o 属性。我找不到解决办法。有人请给我一件救生衣,我正在下沉。
这是我的代码:
const navSlide = () => {
const burger = document.querySelector('.burger');
const nav = document.querySelector('.nav-links');
const navLinks = document.querySelectorAll('.nav-links li');
// Toggle Nav
burger.addEventListener('click', () => {
nav.classList.toggle('nav-active');
//Animate Links
navLinks.forEach((link, index) => {
if (link.style.animation) {
link.style.animation = ''
} else {
link.style.animation = `navLinkFade 0.5s ease forwards ${index / 5 + 0.5}s`;
}
});
// Burger Animation
burger.classList.toggle('toggle');
});
}
navSlide();
// navbar appears after scrolling
let navbar = document.querySelector(".header-navigation");
if (navbar) {
window.addEventListener("scroll", () => {
if (window.scrollY >= window.innerHeight - 70) {
navbar.classList.add('navbar-show');
} else {
navbar.classList.remove('navbar-show')
}
});
}
body {
margin: 0px;
padding: 0px;
box-sizing: border-box;
cursor: pointer;
}
.header-navigation {
opacity: 0;
}
.wrapper {
z-index: 1;
position: relative;
}
.navbar-show {
opacity: 1;
transition: .4s ease-in-out;
position: fixed;
top: 0;
width: 100%;
height: 10vh;
color: black;
background-color: #5D4954;
text-align: right;
box-shadow: rgba(0, 0, 0, 0.05) 0px 4px 12px 0px;
font-family: 'Muli', sans-serif;
font-weight: 600;
overflow: hidden;
z-index: 9999;
cursor: pointer;
}
nav {
display: -webkit-flex;
display: flex;
-webkit-justify-content: space-around;
justify-content: space-around;
-webkit-align-items: center;
align-items: center;
height: 10vh;
font-family: 'Muli', sans-serif;
background-color: white;
transition: .4s ease-in-out;
box-shadow: rgba(0, 0, 0, 0.05) 0px 4px 12px 0px;
cursor: pointer;
}
.logo {
text-transform: uppercase;
letter-spacing: 5px;
font-size: 20px;
color: black;
}
.nav-links {
display: flex;
justify-content: space-around;
width: 40%;
cursor: pointer;
}
.nav-links li {
list-style: none;
cursor: pointer;
}
.nav-links a {
text-decoration: none;
color: black;
letter-spacing: 3px;
font-size: 14px;
display: block;
cursor: pointer;
/* font-weight: bold; */
}
.burger {
display: none;
}
.burger div{
width: 25px;
height: 3px;
background-color: black;
margin: 5px;
transition: all 0.3s ease;
cursor: pointer;
}
@media screen and (max-width: 1024px){
.nav-links {
width: 50%;
}
}
@media screen and (max-width: 768px){
body{
/* overflow-x: hidden;
*/ }
.nav-links {
position: fixed;
right: 0;
height: 92vh;
top: 8vh;
background-color: #5D4954;
display: -webkit-flex;
display: flex;
-webkit-flex-direction: column;
flex-direction: column;
-webkit-align-items: center;
align-items: center;
width: 50%;
-webkit-transform: translateX(100%);
-moz-transform: translateX(100%);
-o-transform: translateX(100%);
transform: translateX(100%);
-webkit-transition: transform 0.5s ease-in;
-moz-transition: transform 0.5s ease-in;
-o-transition: transform 0.5s ease-in;
transition: transform 0.5s ease-in;
cursor: pointer;
}
.nav-links li {
opacity: 0;
-webkit-animation: navLinkFade 0.5s ease forwards 1s;
-moz-animation: navLinkFade 0.5s ease forwards 1s;
-o-animation: navLinkFade 0.5s ease forwards 1s;
-ms-animation: navLinkFade 0.5s ease forwards 1s;
animation: navLinkFade 0.5s ease forwards 1s;
cursor: pointer;
}
.burger {
display: block;
cursor: pointer;
}
}
.nav-active {
-webkit-transform: translateX(0);
-moz-transform: translateX(0);
-o-transform: translateX(0);
transform: translateX(0);
cursor: pointer;
/* z-index: 9999;
position: relative;*/
}
@-webkit-keyframes navLinkFade {
from {
opacity: 0;
transform: translateX(50px);
}
to {
opacity: 1;
transform: translateX(0px);
}
}
@-moz-keyframes navLinkFade {
from {
opacity: 0;
transform: translateX(50px);
}
to {
opacity: 1;
transform: translateX(0px);
}
}
@-o-keyframes navLinkFade {
from {
opacity: 0;
transform: translateX(50px);
}
to {
opacity: 1;
transform: translateX(0px);
}
}
@keyframes navLinkFade {
from {
opacity: 0;
transform: translateX(50px);
}
to {
opacity: 1;
transform: translateX(0px);
}
}
.toggle .line1 {
transform: rotate(-45deg) translate(-5px, 6px);
}
.toggle .line2 {
opacity: 0;
}
.toggle .line3 {
transform: rotate(45deg) translate(-5px, -6px);
}
.banner {
height: 100vh;
background: grey;
color: black;
position: relative;
text-align: center;
}
.banner h1 {
padding-top: 300px;
}
.container1 {
height: 92vh;
background: white;
color: black;
position: relative;
text-align: center;
z-index: 2;
}
.container2 {
height: 92vh;
background: grey;
color: black;
position: relative;
text-align: center;
z-index: 3;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>NAVIGATIOn</title>
<link href="https://fonts.googleapis.com/css?family=Muli:200,300,400,600,700&display=swap" rel="stylesheet">
<link rel="stylesheet" href="style.css">
</head>
<body>
<div class="header-navigation">
<nav class="nav">
<div class="logo">
<h4>NAV</h4>
</div>
<ul class="nav-links">
<li><a href="#">Why a Website?</a></li>
<li><a href="#">About Me</a></li>
<li><a href="#">Contact</a></li>
</ul>
<div class="burger">
<div class="line1"></div>
<div class="line2"></div>
<div class="line3"></div>
</div>
</nav>
</div>
<div class="banner">
<h1>Banner</h1>
</div>
<div class="container1">
<h1>Container1</h1>
</div>
<div class="container2">
<h1>Container2</h1>
</div>
<script src="javascript.js"></script>
</body>
</html>
最佳答案
溢出似乎搞砸了。尽量不要在你的 .navbar-show 中使用 overflow-hidden 🧐
这是一个 JSFiddle:https://jsfiddle.net/RomanVanLoo/5ohva732/6/
body {
margin: 0px;
padding: 0px;
box-sizing: border-box;
cursor: pointer;
}
.header-navigation {
opacity: 0;
}
.wrapper {
z-index: 1;
position: relative;
}
.navbar-show {
opacity: 1;
transition: .4s ease-in-out;
position: fixed;
top: 0;
width: 100%;
height: 10vh;
color: black;
background-color: #5D4954;
text-align: right;
box-shadow: rgba(0, 0, 0, 0.05) 0px 4px 12px 0px;
font-family: 'Muli', sans-serif;
font-weight: 600;
z-index: 9999;
cursor: pointer;
}
nav {
display: -webkit-flex;
display: flex;
-webkit-justify-content: space-around;
justify-content: space-around;
-webkit-align-items: center;
align-items: center;
height: 10vh;
font-family: 'Muli', sans-serif;
background-color: white;
transition: .4s ease-in-out;
box-shadow: rgba(0, 0, 0, 0.05) 0px 4px 12px 0px;
cursor: pointer;
}
.logo {
text-transform: uppercase;
letter-spacing: 5px;
font-size: 20px;
color: black;
}
.nav-links {
display: flex;
justify-content: space-around;
width: 40%;
cursor: pointer;
}
.nav-links li {
list-style: none;
cursor: pointer;
}
.nav-links a {
text-decoration: none;
color: black;
letter-spacing: 3px;
font-size: 14px;
display: block;
cursor: pointer;
/* font-weight: bold; */
}
.burger {
display: none;
}
.burger div{
width: 25px;
height: 3px;
background-color: black;
margin: 5px;
transition: all 0.3s ease;
cursor: pointer;
}
@media screen and (max-width: 1024px){
.nav-links {
width: 50%;
}
}
@media screen and (max-width: 768px){
body{
/* overflow-x: hidden;
*/ }
.nav-links {
position: fixed;
right: 0;
height: 92vh;
top: 8vh;
background-color: #5D4954;
display: -webkit-flex;
display: flex;
-webkit-flex-direction: column;
flex-direction: column;
-webkit-align-items: center;
align-items: center;
width: 50%;
-webkit-transform: translateX(100%);
-moz-transform: translateX(100%);
-o-transform: translateX(100%);
transform: translateX(100%);
-webkit-transition: transform 0.5s ease-in;
-moz-transition: transform 0.5s ease-in;
-o-transition: transform 0.5s ease-in;
transition: transform 0.5s ease-in;
cursor: pointer;
}
.nav-links li {
opacity: 0;
-webkit-animation: navLinkFade 0.5s ease forwards 1s;
-moz-animation: navLinkFade 0.5s ease forwards 1s;
-o-animation: navLinkFade 0.5s ease forwards 1s;
-ms-animation: navLinkFade 0.5s ease forwards 1s;
animation: navLinkFade 0.5s ease forwards 1s;
cursor: pointer;
}
.burger {
display: block;
cursor: pointer;
}
}
.nav-active {
-webkit-transform: translateX(0);
-moz-transform: translateX(0);
-o-transform: translateX(0);
transform: translateX(0);
cursor: pointer;
/* z-index: 9999;
position: relative;*/
}
@-webkit-keyframes navLinkFade {
from {
opacity: 0;
transform: translateX(50px);
}
to {
opacity: 1;
transform: translateX(0px);
}
}
@-moz-keyframes navLinkFade {
from {
opacity: 0;
transform: translateX(50px);
}
to {
opacity: 1;
transform: translateX(0px);
}
}
@-o-keyframes navLinkFade {
from {
opacity: 0;
transform: translateX(50px);
}
to {
opacity: 1;
transform: translateX(0px);
}
}
@keyframes navLinkFade {
from {
opacity: 0;
transform: translateX(50px);
}
to {
opacity: 1;
transform: translateX(0px);
}
}
.toggle .line1 {
transform: rotate(-45deg) translate(-5px, 6px);
}
.toggle .line2 {
opacity: 0;
}
.toggle .line3 {
transform: rotate(45deg) translate(-5px, -6px);
}
.banner {
height: 100vh;
background: grey;
color: black;
position: relative;
text-align: center;
}
.banner h1 {
padding-top: 300px;
}
.container1 {
height: 92vh;
background: white;
color: black;
position: relative;
text-align: center;
z-index: 2;
}
.container2 {
height: 92vh;
background: grey;
color: black;
position: relative;
text-align: center;
z-index: 3;
}
关于javascript - 使用 Javascript 切换的导航栏汉堡的响应式下拉菜单适用于 Chrome、Firefox,但不适用于 Safari,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57891885/
我使用 Runtime.getRuntime().exec 来运行 perl 程序。现在我想在执行过程中显示百分比进度条,然后在perl程序执行完成后,它应该关闭进度条。我该怎么做? Runtime.
我已广泛搜索该网站,但找不到答案。请我是新手,我需要你的帮助。 我想创建一个固定的导航栏,但每次在我的 CSS 样式表中放置一个固定的规则时,导航栏都会消失。这是我的 html 代码:
Here's a nice jsFiddle illustrating the problem 我正在尝试创建一个标题栏元素... 永远只有 1 行高 在右上角有始终存在的控件 在左上角有一个标题,如
int fd = open(JOYSTICK_NAME, O_RDONLY | O_NONBLOCK); O_RDONLY 和 O_NONBLOCK 之间的栏是什么意思?我在 OpenGL/GLUT
我注意到我的网页在页脚之后和页面底部有一个空白/栏: 我试图通过使用 Chrome 中的 inspect 元素来查找此问题的原因,但找不到任何内容。我正在使用 Boostrap,这是我的页脚 HTML
我已经对这个主题进行了一些研究,但我找不到完整的解决方案,因此,我一步一步地尝试和错误,我终于找到了如何实现这些结果:透明或彩色Actionbar 和 Statusbar。请参阅下面的答案。 最佳答案
Highcharts 教程中的经典示例是: $(function () { $('#container').highcharts({ chart: { type: 'bar'
注意 :这与 iOS 13 中使用的新默认模态呈现样式无关。 我有一个奇怪的问题,显示模态 UINavigationController . 考虑一个 UIViewController位于 UINav
我需要帮助了解如何在加载页面时隐藏 iPad 地址栏或顶部的整个地址栏。 我正在开发基于在线客户管理系统的系统,需要隐藏 iPad 地址栏,因为它在查看网站时会占用大量空间。 问候涡流 已经尝试了以下
我在向栏中添加文本时遇到了一些问题。我想在栏上方显示值,但我无法向每个栏添加文本。 现在我的dom结构是: g rect rect rect 我想要什么: g g.bar rect
我有 ListView ,数据将从数据表显示在 ListView 中像这样我已经完成了但是我在数据行 6 有问题 dt = classes.xxxxx.GetData(sql,
我使用 opposite 属性将 xAxis 向右移动。条形图怎么可能也从右侧开始? 谢谢! Highcharts.chart('absoluteInterruptions', { chart:
我得到了这张图片,我想在我的导航 Controller 中使用它: 我是这样设置的(根据 this 问题的建议): UINavigationBar *theBar = self.navigationC
这个问题在这里已经有了答案: How to disable breadcrumbs in Eclipse (11 个答案) 关闭 9 年前。 有谁知道如何删除我在 Eclipse 中用红色圈出的栏?
总而言之,我的应用程序中有一个浏览器,我希望它只启动 5 个网站,仅此而已。有没有办法让我的浏览器通过设置自定义字符串来启动 5 个网站,例如 if {用户键入此字符串} 转到该网站,然后 else
我想在我的应用程序中实现一个进度条。发生的过程是应用程序将一个目录复制到 iOS 文档目录中。通常需要 7-10 秒(iPhone 4 测试)。我对进度条的理解是你在事情发生时更新进度条。但是根据目录
我正在寻找一种创建交互式子弹图的方法,它允许用户单击图中的任意位置并设置一个标记,然后根据该标记所在的位置计算一些简单的值。例如,我希望它看起来类似于: http://www.usrecordings
我目前在一个网站上工作,我有一张人的照片。在图片的右侧,我想要名称和描述。名称应与描述具有不同的背景。我上传了一张它应该是什么样子的图片:http://www.tiikoni.com/tis/view
我将 div 栏设置为不滚动,因此它将始终显示在网站顶部。在这个栏内,我有另一个 div 框,里面有两个按钮,它们向右浮动,所以它们总是在右上角。 问题是我希望按钮居中于页面的右上角而不是右上角。相反
因此,我在我的网站中使用了一个选择栏。我试图在悬停时更改选项的背景颜色。此外,如果有人知道设置垂直 slider 样式的好方法,那就太棒了。 这是我正在尝试做的事情的 fiddle : http://
我是一名优秀的程序员,十分优秀!