html - 将媒体查询从最大宽度反转为最小宽度
问题描述
基本上,我找到了一个我想使用的很好的响应式导航栏,但它的@media
查询设置为max-width: 600px
. 我想将其设置为最小尺寸,320 像素和 786 像素。我通常能够反转代码以适应,但我真的坚持这个。
这是 CodePen 的链接:https ://codepen.io/jo_Geek/pen/xgbaEr
和代码本身:
* {
box-sizing: border-box;
}
body {
margin: 0px;
font-family: 'segoe ui';
}
.nav {
height: 50px;
width: 100%;
background-color: #4d4d4d;
position: relative;
}
.nav>.nav-header {
display: inline;
}
.nav>.nav-header>.nav-title {
display: inline-block;
font-size: 22px;
color: #fff;
padding: 10px 10px 10px 10px;
}
.nav>.nav-btn {
display: none;
}
.nav>.nav-links {
display: inline;
float: right;
font-size: 18px;
}
.nav>.nav-links>a {
display: inline-block;
padding: 13px 10px 13px 10px;
text-decoration: none;
color: #efefef;
}
.nav>.nav-links>a:hover {
background-color: rgba(0, 0, 0, 0.3);
}
.nav>#nav-check {
display: none;
}
@media (max-width:600px) {
.nav>.nav-btn {
display: inline-block;
position: absolute;
right: 0px;
top: 0px;
}
.nav>.nav-btn>label {
display: inline-block;
width: 50px;
height: 50px;
padding: 13px;
}
.nav>.nav-btn>label:hover {
background-color: rgba(0, 0, 0, 0.3);
}
.nav>.nav-btn>label>span {
display: block;
width: 25px;
height: 10px;
border-top: 2px solid #eee;
}
.nav>.nav-links {
position: absolute;
display: block;
width: 100%;
background-color: #333;
height: 0px;
transition: all 0.3s ease-in;
overflow-y: hidden;
top: 50px;
left: 0px;
}
.nav>.nav-links>a {
display: block;
width: 100%;
}
.nav>#nav-check:not(:checked)+.nav-links {
height: 0px;
}
.nav>#nav-check:checked+.nav-links {
height: calc(100vh - 50px);
overflow-y: auto;
}
}
<div class="nav">
<div class="nav-header">
<div class="nav-title">
JoGeek
</div>
</div>
<div class="nav-btn">
<label for="nav-check">
<span></span>
<span></span>
<span></span>
</label>
</div>
<input type="checkbox" id="nav-check">
<div class="nav-links">
<a href="//github.io/jo_geek" target="_blank">Github</a>
<a href="http://stackoverflow.com/users/4084003/" target="_blank">Stackoverflow</a>
<a href="https://in.linkedin.com/in/jonesvinothjoseph" target="_blank">LinkedIn</a>
<a href="https://codepen.io/jo_Geek/" target="_blank">Codepen</a>
<a href="https://jsfiddle.net/user/jo_Geek/" target="_blank">JsFiddle</a>
</div>
</div>
解决方案
你必须使用
@media (min-width: 320px) and (max-width: 786px) {
//CSS
}
推荐阅读
- node.js - 如何将大量数据上传到 Firebase Firestore
- oracle - 当 job_action 需要调用具有 CLOB 参数的过程时,如何创建作业
- python - Google Stackdriver 使用 Redis 队列登录 App Engine (Python)
- javascript - 如何在语义-ui反应的下拉文本字段中添加新行?
- jenkins - 无法建立 JDBC 连接
- azure - 还原 Azure 媒体服务的已删除资产
- docusignapi - 当单击在iframe中加载的Docusign标记界面的发送按钮时,当控件返回到returnurl时如何关闭iframe?
- database - `test-on-borrow` 有什么作用?
- c# - SQL Server 2008 R2、Crystal Report 和 asp.net 问题
- php - 用php编码utf8