美文网首页
阻止a跳转:a标签href属性 与 ng-href指令

阻止a跳转:a标签href属性 与 ng-href指令

作者: _信仰zmh | 来源:发表于2018-09-25 17:40 被阅读1188次

    我们都知道a标签自带跳转功能,只要你指定它的href属性即跳转地址,就会往对应的地址跳转。

    1. 如果不想跳转怎么办?

    js做法:

    • 指定a标签href属性,使其指向空不返回任何内容,如下:
    <a href="javascript:void(0);" >点此不跳转</a>
    <a href="javascript:;" >点此也不跳转</a>
    
    • 添加onclick事件,阻止其默认行为,示例如下:
    <a href="" onclick="return false;">click不跳</a>
    <a href="#" onclick="return false;">click不跳2</a>
    

    注意:只有一个href="#"是不可以的。

    1.2 原理:

    标签属性href="javascript:void(0);" 关键是理解void(0)的含义。
    javascript中void是一个操作符,该操作符指定要计算一个表达式但是不返回值。

    用法格式如下:

    a). javascript:void (expression)

    b). javascript:void expression

    你以使用 void 操作符指定超级链接。表达式会被计算但是不会当前文档处装入任何内容。所以,javascript:void(0) 仅仅表示一个死链接。

    只有href="#"不可以的,因为#包含了一个位置信息,默认的是#top 也就是网页的上端。我理解的锚是指网页中具体位置。

    • #锚链接用法例如:

    首先我们在网页body内最上面添加一个<span id="top" name="top"></span>

    我们再到body内,需要出现点击后转到顶部位置添加,<a href="#top">回到顶部</a>

    点击回到顶部即可让滚动回到顶部。


    标签事件onclick="return false;" 在HTML代码中,无论你在哪里放置了onclick事件,并且返回值为false时,那么该处的默认行为将不会执行。这里的默认行为是指没有Onclick事件时原本的行为。


    2. ng-href 指令,阻止其跳转

    在angular中,可以动态的改变href值,实现灵活化。

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    <script src="https://cdn.bootcss.com/angular.js/1.4.6/angular.min.js"></script>
    </head>
    <body ng-app="">
    
    <div ng-init="myVar = 'http://www.runoob.com'">
    <h1>菜鸟教程</h1>
    <p>访问 <a ng-href="{{myVar}}">{{myVar}}</a> 学习!</p>
    </div>
    
    <p>该实例可以使用了原生的 href 属性,但在 AngularJS 中, ng-href 属性更安全。</p>
    
    </body>
    </html>
    

    如果不想让其跳转的话,我们就设置ng-href后面的表达式空字符串,即""即可,这样a链接就不会触发跳转。

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    <script src="https://cdn.bootcss.com/angular.js/1.4.6/angular.min.js"></script>
    </head>
    <body ng-app="">
    // 为空不跳转
    <div ng-init="myVar = '' ">
    <h1>菜鸟教程</h1>
    <p>访问 <a ng-href="{{myVar}}">{{myVar}}ggggggggggg</a> 学习!</p>
    </div>
    
    <p>该实例可以使用了原生的 href 属性,但在 AngularJS 中, ng-href 属性更安全。</p>
    
    </body>
    </html>
    

    如果你将ng-href后的表达式设置为javascript:void(0);是不行的,依旧会跳转,除非设置成""

    ng-href会对href表达式进行一下检查是否合法,具体请参考ng-href的源码。

    本文章参考博客地址

    相关文章

      网友评论

          本文标题:阻止a跳转:a标签href属性 与 ng-href指令

          本文链接:https://www.haomeiwen.com/subject/urvloftx.html