私の質問が少し具体的すぎることはわかっていますが、問題を解決できません。
ここに私のデモがあります: http://jsfiddle.net/NWMST/ (CSS にいくつかのコメントがあることがわかりますが、いくつかは無視できます...)
問題:デフォルトでは、メニューの角が丸くなっていることに注意してください (border-radius)。クリックしてメニューを引き出すと、上部の 2 つの角の境界半径がなくなります。ただし、もう一度クリックして閉じると、上隅は同じままで、境界線の半径はありません...
ここstackoverflowで見つけたスニペットを使ってさまざまな試みをしましたが、探しているソリューションはどこにもありません。こんなことを聞いて申し訳ありません。jQuery はそれを操作することしか理解していませんが、自分でスクリプトをプログラムすることはほとんどできません。
私が使用したプル チュートリアル: http://www.hongkiat.com/blog/responsive-web-nav/
マークアップ、スタイル、およびスクリプトは次のとおりです (ただし、実際に問題が何であるかを確認するために、デモでライブを見ることができます)。
HTML マークアップ:
<nav id="menu" class="clearfix">
<ul class="clearfix">
<li><a class="current first-item" href="#">Home</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Portfolio</a></li>
<li><a href="#">Blog</a></li>
<li><a href="#">Contact</a></li>
</ul>
<a href="#" id="pull">Menu</a>
</nav>
CSS:
#menu a {text-decoration: none; }
#menu ul {display: none; }
#menu {text-align: center; }
#menu #pull {
display: block;
position: relative;
display: block;
font: 700 19px/1.45em 'Open Sans', Arial, sans-serif;
color: #2e2e2e;
padding: 8px 0 6px;
border: 1px solid #bdc4c7;
background: #fff;
-webkit-box-shadow: none;
box-shadow: none;
-webkit-border-radius: 3px;
border-radius: 3px;
}
/* the rule I'm using on the script */
#menu #pull.radius {
-webkit-border-radius: 0 0 3px 3px;
border-radius: 0 0 3px 3px;
}
#menu #pull i {
font-size: 25px;
padding-right: 10px;
}
#menu #pull:hover,
#menu #pull:focus,
#menu #pull:active {color: #04bfee; }
#menu {
float: none;
clear: both;
}
#menu li {
float: none;
margin: 0;
}
#menu li a {
position: relative;
display: block;
font: 700 12px/1em 'Open Sans', Arial, sans-serif;
text-transform: uppercase;
color: #2e2e2e;
padding: 8px 12px 6px;
border: 1px solid #bdc4c7;
border-bottom: 0 none;
background: #fff;
-webkit-box-shadow: none;
box-shadow: none;
-webkit-border-radius: 0;
border-radius: 0;
}
#menu li a.current,#menu li a:hover,#menu li a:focus {
color: #0abcff;
border: 0 none;
border: 1px solid #bdc4c7;
border-bottom: 0 none;
background: #fafafa;
-webkit-box-shadow: none;
box-shadow: none;
}
#menu li a.first-item {
-webkit-border-radius: 3px 3px 0 0;
border-radius: 3px 3px 0 0;
}
JQUERY スクリプト:
$(function() {
var pull = $('#pull');
menu = $('#menu ul');
menuHeight = menu.height();
$(pull).on('click', function(e) {
if($(this).is('.radius')) {$(this).removeClass('radius');}
$(this).addClass('radius').siblings().removeClass('radius');
e.preventDefault();
menu.slideToggle();
});
});
$(window).resize(function(){
var w = $(window).width();
if(w > 767 && menu.is(':hidden')) {
menu.removeAttr('style');
}
});
どうもありがとう。