javascript - HASHTAG HARDSHIPS - 如何在 URL 中不放置 hashtag 的情况下打开菜单下拉列表?

标签 javascript html css mobile hashtag

所以这是我的问题。假设我有一个菜单栏,当用户通过移动设备点击它时,它应该变成一个下拉菜单。说我也讨厌当我点击所述菜单时我的网址后面出现#符号(例如www.google.com/#)定位到 anchor 标签, anchor 标签也隐藏了 # 符号。但出于某种原因,我在尝试让我的菜单在小屏幕上打开时遇到问题!

这是菜单html

<div class=navmover>
    <nav id="effect" class="newClass">
        <ul>
            <li id="mobibutton" class="lightupmobi">
                <a href="#" id="button">
                    <div style="display:block !important;position:relative !important;top:8px !important;padding-left:0.5em !important;right:3px !important;text-align:left !important;">MENU</div>
                    <img id="mobibutton" src="images/nav-icon.png" style="position:relative !important;left:40% !important;">
                </a>
            </li>
            <li id="hideme" class="lightup">
                <a id=link1 href=#intro>Top</a>
            </li>
            <li id="hideme" class="lightup">
                <a id=link2 href=#work>Work</a>
            </li>
            <li id="hideme" class="lightup">
                <a id=link3 href=#services>Services</a>
            </li>
            <li id="hideme" class="lightup">
                <a id=link4 href=#about>About</a>
            </li>
            <li id="hideme" class="lightup">
                <a id=link5 href=#contact>Contact</a>
            </li>
        </ul>
    </nav>
</div>

用于打开和关闭菜单的javascript

<!--Show Hide Button JS-->
<script>
    $(function() {
        $("#button1").click(function() {
            $("#effect").toggleClass("newClass", 1000);
            $("li").toggleClass("showme", 1000);
            return false;
        });
    });
</script>

用于在 anchor 之间平滑滚动的 javascript

<script type=text/javascript>
    $(document).ready(function() {
        $("#link1").anchorScroll({fx:"easeInOutExpo"});
        $("#link2").anchorScroll({fx:"easeInOutExpo"});
        $("#link3").anchorScroll({fx:"easeInOutExpo"});
        $("#link4").anchorScroll({fx:"easeInOutExpo"});
        $("#link5").anchorScroll({fx:"easeInOutExpo"});
        $("#link6").anchorScroll({fx:"easeInOutExpo"});
        $("#link7").anchorScroll({fx:"easeInOutExpo"});
    });
</script>

<script type=text/javascript>
    function scrollTo(b) {
        var a=$(b).offset().top;
        $("html,body").animate({scrollTop:a},"slow");
    }
</script>

站点中的其余 javascript。抱歉...我意识到它有很多值得一看的地方。

<script async type="text/javascript" src="//cdn.sublimevideo.net/js/kmaxx7p4.js"></script>
<script type="text/javascript" src="http://jzaefferer.github.com/jquery-validation/jquery.validate.js"></script>
<script async src=javascripts/svg.js></script>
<script src=javascripts/jquery.js></script>
<script src=http://html5shim.googlecode.com/svn/trunk/html5.js></script>
<script src=http://code.jquery.com/jquery-1.9.1.min.js></script>
<script src=javascripts/jquery-migrate-1.2.1.min.js></script>
<script src=javascripts/jquery.animate.js type=text/javascript></script>
<script src=javascripts/jquery.scrollanchor.js type=text/javascript></script>
<script src=javascripts/jquery.sticky.js type=text/javascript></script>
<script async src=javascripts/jquery.inview.js type=text/javascript></script>
<script async src=javascripts/jquery.flexslider.js type=text/javascript></script>
<script async src=javascripts/jquery.prettyPhoto.js type=text/javascript></script>
<script src=http://vjs.zencdn.net/c/video.js></script>
<script type=text/javascript>function ReplaceContentInContainer(c,b){var a=document.getElementById(c);a.innerHTML=b}</script>
<script type=text/javascript>function preload(a){$(a).each(function(){$("<img/>")[0].src=this})}preload(["images/bg.png","images/cloudscape2.png","images/logo2.svg","images/logo2.png",]);</script>
<script>$(function(){$(".two").css("opacity",0).fadeTo(0,0);$(".one").on("mouseenter mouseleave",function(a){var b=a.type=="mouseenter"?$(".two",this).stop().fadeTo(200,1):$(".two",this).stop().fadeTo(200,0)})});</script>
<script>$(document).ready(function(){$("nav").sticky({topSpacing:0})});</script>
<script type=text/javascript>$(document).ready(function(){$("#link1").anchorScroll({fx:"easeInOutExpo"});$("#link2").anchorScroll({fx:"easeInOutExpo"});$("#link3").anchorScroll({fx:"easeInOutExpo"});$("#link4").anchorScroll({fx:"easeInOutExpo"});$("#link5").anchorScroll({fx:"easeInOutExpo"});$("#link6").anchorScroll({fx:"easeInOutExpo"});$("#link7").anchorScroll({fx:"easeInOutExpo"});});</script>
<script type=text/javascript>function scrollTo(b){var a=$(b).offset().top;$("html,body").animate({scrollTop:a},"slow");}</script>
<script>$(window).load(function(){$(".flexslider").flexslider({animation:"slide",slideshow:true,slideshowSpeed:3500,animationSpeed:1000})});</script>
<script type=text/javascript charset=utf-8>$(document).ready(function(){$("a[rel^='prettyPhoto']").prettyPhoto({social_tools:false,theme:"light_square"})});</script>

如果迫在眉睫,我还可以提供指向我的网站的链接,这样您就可以在手机/平板电脑上亲眼看到我遇到的问题。让我知道我是否过于含糊,你们也需要更多信息。请帮忙,谢谢!

最佳答案

不要使用 #作为你的href值(value)。有很多不同的方法可以像您尝试做的那样“无目标”,包括:

  • 使用event.preventDefault()在绑定(bind)到您的事件的代码中,忽略默认链接行为
  • 使用return false;在绑定(bind)到您的事件的代码末尾,一起中断事件的任何进一步处理
  • 使用href="javascript: void(0);"作为你的目标 <a>标记,使目标“什么都不做”

. . .并且还有其他变体,具体取决于情况(例如,event.stopPropagation() 以阻止事件触发所有元素祖先,而不是当前元素)。

就我个人而言,在这种特殊情况下,我会去 href="javascript: void(0);"路线,但你有一些回旋余地,可以想出你喜欢的方法。


更新:想一想,您使用 <a> 是有原因的吗?标签开头(例如,样式原因)?您可以简单地将点击绑定(bind)到 <li>相反,并从等式中一起删除链接行为。 . .

关于javascript - HASHTAG HARDSHIPS - 如何在 URL 中不放置 hashtag 的情况下打开菜单下拉列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23434643/

相关文章:

javascript - 窄文本区域中的上下键

javascript - 背景图像在 Chrome 的某些屏幕尺寸上突然消失

javascript - 一开始如何不启用切换类?

javascript - angular ng-repeat 根据条件添加样式

javascript - 如何将自定义 JS 文件导入到 React 单页应用程序中?

javascript - 使用 Web api 并获取引用错误

html - 图片导航 CSS

javascript - 如何在 x 轴上设置固定金额,以便显示 future 的时间?

html - border-radius 在表单元素文本中只显示两条边

html - CSS3 - 不同 HTML 元素之间的混合模式