不同屏幕分辨率的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函数[重复]的主要内容,如果未能解决你的问题,请参考以下文章