不同屏幕分辨率的javascript函数[重复]

Posted

技术标签:

【中文标题】不同屏幕分辨率的javascript函数[重复]【英文标题】:java script function for different screen resolution [duplicate] 【发布时间】:2019-12-29 05:58:08 【问题描述】:

我是 js 新手,正在研究 侧边栏导航,我阅读了 w3school 教程 这是一个脚本,但它只适用于桌面全屏浏览器。

<script>
function openNav() 
  document.getElementById("mySidebar").style.width = "250px";
  document.getElementById("main").style.marginLeft = "250px";


function closeNav() 
  document.getElementById("mySidebar").style.width = "0";
  document.getElementById("main").style.marginLeft= "0";

</script>

你可以看到它扩展宽度250px,但为了让它响应移动浏览器它应该扩展70-80px

如何针对不同的分辨率运行它?

【问题讨论】:

看看 CSS 媒体查询 @LeeTaylor 我是 js 新手,请参考我。 @LeeTaylor 我做到了,但什么也没找到。 @JaredSmith 我确实接受它是重复的,但是您向我展示的内容是关于与样式相关的媒体查询而不是 js.btw 我不相信,它是重复的。如果我错了,请纠正我认真去学js了。 【参考方案1】:

使用window.innerWidth获取用户的窗口宽度

function openNav() 
  if (window.innerWidth > 600) 
    document.getElementById("mySidebar").style.width = "250px";
    document.getElementById("main").style.marginLeft = "250px";
   else 
    document.getElementById("mySidebar").style.width = "70px";
    document.getElementById("main").style.marginLeft = "80px";
  


【讨论】:

我会测试,请稍候。 为什么不起作用? @Mr.AF 我的猜测是 '600' px 比您测试的屏幕大...。如果您使用的是桌面,请在条件语句中减少它或使用浏览器宽度跨度> 我按 ctrl+f12 将屏幕停留在 600px 以下 当我再次发布时,宽度调整为 70 像素,但在打开导航时再次调整为 250 像素【参考方案2】:

您可以使用css @media query,这是理想的选择。但是,如果您特定于 JS,那么请在下面尝试使用 document.body.offsetWidth

function openNav() 
  if (document.body.offsetWidth < 600) 
    document.getElementById("mySidebar").style.width = "70px";
    document.getElementById("main").style.marginLeft = "70px";
   else 
    document.getElementById("mySidebar").style.width = "250px";
    document.getElementById("main").style.marginLeft = "250px";
  


function closeNav() 
  document.getElementById("mySidebar").style.width = "0";
  document.getElementById("main").style.marginLeft = "0";
.sidebar 
  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;


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


.sidebar a:hover 
  color: #f1f1f1;


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


.openbtn 
  font-size: 20px;
  cursor: pointer;
  background-color: #111;
  color: white;
  padding: 10px 15px;
  border: none;


.openbtn:hover 
  background-color: #444;


#main 
  transition: margin-left .5s;
  padding: 16px;



/* 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) 
  .sidebar 
    padding-top: 15px;
  
  .sidebar a 
    font-size: 18px;
  
<div id="mySidebar" class="sidebar">
  <a href="javascript:void(0)" class="closebtn" onclick="closeNav()">×</a>
  <a href="#">About</a>
  <a href="#">Services</a>
  <a href="#">Clients</a>
  <a href="#">Contact</a>
</div>

<div id="main">
  <button class="openbtn" onclick="openNav()">☰ Toggle Sidebar</button>
  <h2>Collapsed Sidebar</h2>
  <p>Click on the hamburger menu/bar icon to open the sidebar, and push this content to the right.</p>
</div>

【讨论】:

我会测试它,请稍候。 不起作用... 我也清除了浏览器历史记录。 @Mr.AF 编辑了我的代码。 很好。请稍等。

以上是关于不同屏幕分辨率的javascript函数[重复]的主要内容,如果未能解决你的问题,请参考以下文章

移动端,多屏幕尺寸高清屏retina屏适配的解决方案

video全屏视频背景适配不同分辨率

为移动设备、低分辨率桌面和高分辨率桌面编写媒体查询 [重复]

虚拟机的linux怎么全屏显示

网页怎么在不同的屏幕分辨率下显示正常

安卓手机上一个5.0寸按竖屏屏幕的一半屏幕分辨率约是多少乘多少