CSS 媒体查询内的 Javascript 切换样式显示在媒体查询显示外中断

标签 javascript html css media-queries

我有一个只在 CSS 媒体查询中显示的交互式元素,它将另一个元素(nav 元素)的显示从无切换为阻止。在媒体查询之外(任何显示宽度大于 580 像素)导航元素显示设置为 block 。当我在媒体查询中切换显示并将导航设置为不显示,然后将浏览器的大小重新调整为大于 580 像素的宽度时,导航元素仍设置为不显示。我怎样才能使在媒体查询中切换导航的显示不会影响它在媒体查询之外的显示?

<!-- Toggle Display
	// click on the element
	function toggle(e, id) {
		var el = document.getElementById(id);
		
		el.style.display = (el.style.display == 'none' || el.style.display == '') ? 'block' : 'none';

		// save it for hiding
		toggle.el = el;
		

		// stop the event here
		if (e.stopPropagation) e.stopPropagation();
		e.cancelBubble = true;
		return false;
	}

	// click outside the element
	document.onclick = function() {
		if (toggle.el) {
			toggle.el.style.display = 'none';
		}
	}
//-->
nav {
  color: white ;
  float: right ;
  margin: 0 10px 0 0 ;
  display: block ;

}


nav a {
  margin-right: 25px ;
  padding: 5px 4px 2px 4px ;
  display: inline-block ;
}

.nav-text { 
  display: none ; /* replaced by icons */
  font-size: 18px ;
}

@media all and (max-width: 580px) {
   
   nav {
     display: none ;
     float: left ;
     width: 100% ;
     margin: 3px 0 0 0 ;
     clear: both ;
   }
   
   .menu {
     display: block ;
  }
  
    nav a {
     display: block ;
     background: gray ;
     color: white ;
     padding: 10px 20px ;
     width: 100% ;
     border-bottom: 1px solid #ccc ;
  }
  
}
<header>

  <div onclick="toggle(event, 'nav')" class="menu" tabindex=0> 

    <!-- Menu icon -->
 
  </div>

  <nav id="nav">
    <a href="/"><span class="nav-text">Home</span></a>
    <a href="#"><span class="nav-text">About</span></a>
  </nav>

</header>

最佳答案

当您使用 Javascript 代码设置 display:none 时,它会被设置为内联样式,它会覆盖 CSS 文件、媒体查询或其他内容中的任何内容。

解决此问题的最简单方法是将 !important 添加到媒体查询中的 display:block,但这有点草率。

或者,如果您真的想通过 Javascript 使用此切换功能,您可以向窗口添加一个监听器以检测屏幕宽度的变化。因此,如果窗口的大小超过 580 像素(或您想要的任何大小),它可以检查并确保清除任何内联 css。

关于CSS 媒体查询内的 Javascript 切换样式显示在媒体查询显示外中断,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29661385/

相关文章:

javascript - 使用javascript将大型html表格导出到excel

html - CSS 颜色在 Windows Phone 8.1 的 IE 中不显示(在其他地方工作)

javascript - <section> 后的空格

html - 重复嵌套交替样式

javascript - 在文档准备好图像源后使用 JQuery 居中图像

javascript - 表在附加行后失去对齐

javascript - 循环显示 3 种颜色然后返回原始颜色

jquery - 更改 ftp css 样式

javascript - SyntaxError : Unexpected token '=' . 参数声明后应为 ')' 或 ','。在 Safari

html - 图像上的 Safari 绝对位置问题