如果 window 宽度小于 600,则单击下拉菜单
On click dropdown if window width is less than 600
我是 JS 新手。
我正在尝试通过执行此操作在向现有 CSS 添加一些 CSS 代码之间切换(我认为这是 JQuery)。
$('#navIt').click(function () {
$('#navIt').addClass('.drop', $(window).width() < 600);
}, function () {
$('#navIt').removeClass('.drop', $(window).width() < 600);
});
我不知道这是否是正确的代码。我从 here and here 找到了这个,但它似乎对我不起作用。
Html
<div id="navIt" class="nav">
<ul>
<li class="current"><a>Portfolio</a></li>
<li><a>Illustration</a></li>
<li><a>Web Design</a></li>
<li><a>Print Media</a></li>
<li><a>Graphic Design</a></li>
</ul>
</div>
CSS
/* nav */
.nav {
position: relative;
margin: 20px 0;
}
.nav ul {
margin: 0;
padding: 0;
}
.nav li {
margin: 0 5px 10px 0;
padding: 0;
list-style: none;
display: inline-block;
}
.nav a {
padding: 3px 12px;
text-decoration: none;
color: #999;
line-height: 100%;
}
.nav a:hover {
color: #000;
}
.nav .current a {
background: #999;
color: #fff;
border-radius: 5px;
}
/* right nav */
.nav.right ul {
text-align: right;
}
/* center nav */
.nav.center ul {
text-align: center;
}
@media screen and (max-width: 600px) {
.nav {
position: relative;
min-height: 40px;
}
.nav ul {
width: 180px;
padding: 5px 0;
position: absolute;
top: 0;
left: 0;
border: solid 1px #aaa;
background: #fff url(images/icon-menu.png) no-repeat 10px 11px;
border-radius: 5px;
box-shadow: 0 1px 2px rgba(0,0,0,.3);
}
.nav li {
display: none; /* hide all <li> items */
margin: 0;
}
.nav .current {
display: block; /* show only current <li> item */
}
.nav a {
display: block;
padding: 5px 5px 5px 32px;
text-align: left;
}
.nav .current a {
background: none;
color: #666;
}
/* right nav */
.nav.right ul {
left: auto;
right: 0;
}
/* center nav */
.nav.center ul {
left: 50%;
margin-left: -90px;
}
}
@media screen and (max-width: 600px) {
/*on click hover */
.drop ul {
background-image: none;
}
.drop ul li {
display: block;
margin: 0 0 5px;
}
.drop ul .current {
background: url(images/icon-check.png) no-repeat 10px 7px;
}
}
最后,我想做的是,如果window尺寸小于600,我应该可以在.drop
class之间切换。
知道怎么做吗?
像这样添加或删除它,使用简单 if/else
$('#navIt').click(function () {
if($(window).width() < 600){
$(this).addClass('drop');
}
else{
$(this).removeClass('drop');
}
});
参考.addClass():https://api.jquery.com/addclass/
一个例子应该清楚:
https://jsfiddle.net/wdof7fxt/
只需调整浏览器的大小 window,您就会看到方形 red/white。根据您的需要进行调整。
JavaScript
$(window).on('resize', function() {
if($(this).width() > 600) {
$('#box').css('background-color', 'white');
}
else {
$('#box').css('background-color', 'red');
}
});
我是 JS 新手。
我正在尝试通过执行此操作在向现有 CSS 添加一些 CSS 代码之间切换(我认为这是 JQuery)。
$('#navIt').click(function () {
$('#navIt').addClass('.drop', $(window).width() < 600);
}, function () {
$('#navIt').removeClass('.drop', $(window).width() < 600);
});
我不知道这是否是正确的代码。我从 here and here 找到了这个,但它似乎对我不起作用。
Html
<div id="navIt" class="nav">
<ul>
<li class="current"><a>Portfolio</a></li>
<li><a>Illustration</a></li>
<li><a>Web Design</a></li>
<li><a>Print Media</a></li>
<li><a>Graphic Design</a></li>
</ul>
</div>
CSS
/* nav */
.nav {
position: relative;
margin: 20px 0;
}
.nav ul {
margin: 0;
padding: 0;
}
.nav li {
margin: 0 5px 10px 0;
padding: 0;
list-style: none;
display: inline-block;
}
.nav a {
padding: 3px 12px;
text-decoration: none;
color: #999;
line-height: 100%;
}
.nav a:hover {
color: #000;
}
.nav .current a {
background: #999;
color: #fff;
border-radius: 5px;
}
/* right nav */
.nav.right ul {
text-align: right;
}
/* center nav */
.nav.center ul {
text-align: center;
}
@media screen and (max-width: 600px) {
.nav {
position: relative;
min-height: 40px;
}
.nav ul {
width: 180px;
padding: 5px 0;
position: absolute;
top: 0;
left: 0;
border: solid 1px #aaa;
background: #fff url(images/icon-menu.png) no-repeat 10px 11px;
border-radius: 5px;
box-shadow: 0 1px 2px rgba(0,0,0,.3);
}
.nav li {
display: none; /* hide all <li> items */
margin: 0;
}
.nav .current {
display: block; /* show only current <li> item */
}
.nav a {
display: block;
padding: 5px 5px 5px 32px;
text-align: left;
}
.nav .current a {
background: none;
color: #666;
}
/* right nav */
.nav.right ul {
left: auto;
right: 0;
}
/* center nav */
.nav.center ul {
left: 50%;
margin-left: -90px;
}
}
@media screen and (max-width: 600px) {
/*on click hover */
.drop ul {
background-image: none;
}
.drop ul li {
display: block;
margin: 0 0 5px;
}
.drop ul .current {
background: url(images/icon-check.png) no-repeat 10px 7px;
}
}
最后,我想做的是,如果window尺寸小于600,我应该可以在.drop
class之间切换。
知道怎么做吗?
像这样添加或删除它,使用简单 if/else
$('#navIt').click(function () {
if($(window).width() < 600){
$(this).addClass('drop');
}
else{
$(this).removeClass('drop');
}
});
参考.addClass():https://api.jquery.com/addclass/
一个例子应该清楚: https://jsfiddle.net/wdof7fxt/
只需调整浏览器的大小 window,您就会看到方形 red/white。根据您的需要进行调整。
JavaScript
$(window).on('resize', function() {
if($(this).width() > 600) {
$('#box').css('background-color', 'white');
}
else {
$('#box').css('background-color', 'red');
}
});