• 技术文章 >web前端 >Bootstrap教程

    如何解决bootstrap导航条不跳转的问题

    藏色散人藏色散人2020-12-04 09:00:48原创550

    bootstrap导航条不跳转的解决办法:1、使用“$('#myTabs a').click(function (e){...}”方式;2、使用“data-toggle”标记;3、通过“window.location”实现跳转即可。

    本教程操作环境:Windows7系统、bootstrap3版,该方法适用于所有品牌电脑。

    推荐:《bootstrap视频教程

    最近在学习bootstrap,准备做一个个人网站的主页。前端就准备采用bootstrap来做了,因为,bootstrap确实很漂亮,也很流行,有了问题也方便通过百度或者谷歌找到答案。

    我的页面大概是这个样子:

    1e97bbbf2249db3a002785d2a80a51b.png

    主要就是采用bootstrap的navbar组件设计了一个自己的导航条,以为很简单的事情,结果最后导航条没有工作。

    问题:

    1、导航条不按照点击切换相应tab的active状态。链接能够正常跳转,但是始终是Home处于激活状态。

    对于这个问题首先百度了一下,可能的原因在于jquery库引用不正确,jquery库的引用一定要在bootstrap库之前,因为bootstrap依赖jquery库工作。

    但是我检查了一遍自己的代码后,发现我的引用顺序并没有问题。

    接下来,我在bootstrap官网中找到这样一句话(我使用的是bootstrap3)

    43120828fcaaa95d3085dd600067c68.png

    截图地址:https://v3.bootcss.com/javascript/#tabs

    这里表明有两种方法可以激活tab,第一种是通过如下的javascript代码:

    $('#myTabs a').click(function (e) {
      e.preventDefault()
      $(this).tab('show')})

    第二种是通过"data-toggle"标记

    <ul class="nav nav-tabs" role="tablist">
        <li role="presentation" class="active"><a href="#home" aria-controls="home" role="tab" data-toggle="tab">Home</a></li>
        <li role="presentation"><a href="#profile" aria-controls="profile" role="tab" data-toggle="tab">Profile</a></li>
        <li role="presentation"><a href="#messages" aria-controls="messages" role="tab" data-toggle="tab">Messages</a></li>
        <li role="presentation"><a href="#settings" aria-controls="settings" role="tab" data-toggle="tab">Settings</a></li>
      </ul>

    采用任意一种方法后,navbar active状态不随点击改变的问题解决了,但是发现导航条中也就是<ul></ul>标记中所有<a>标记的href属性都失效了,后来也是一顿搜索,发现,bootstrap把href属性当id处理,只链接到当前页面的位置,而外部跳转链接被屏蔽。

    参考:(https://stackoverflow.com/questions/16785264/jquery-syntax-error)

    2、解决了第一项问题后,结果发现navbar中的链接无法跳转到外部链接。

    正如前面提到,外部链接被屏蔽,后来只好想到通过js来实现跳转,因此,我把navbar的激活代码修改了一下,通过window.location来实现跳转。

    $(function () {
          $("#myBar li").click(function (e) {
            e.preventDefault()
            $(this).tab('show')      
            window.location.href = 'http://localhost:3000' + $(this).children('a').attr('href')
          })
     })

    这样才算解决了bootstap 导航条的问题。但总觉得应该有更好的解决方法,希望个为朋友给个建议吧。

    以上就是如何解决bootstrap导航条不跳转的问题的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:bootstrap
    上一篇:浅谈bootstrap表单验证插件BootstrapValidator 下一篇:bootstrap 为什么只能默认12列
    大前端线上培训班

    相关文章推荐

    • bootstrap 如何设置移动端元素隐藏• bootstrap删格系统是什么• bootstrap4有哪些版本?• vue.js怎么引入bootstrap

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网