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

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

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

js做法:

  • 指定a标签href属性,使其指向空不返回任何内容,如下:
点此不跳转
点此也不跳转
  • 添加onclick事件,阻止其默认行为,示例如下:
click不跳
click不跳2

注意:只有一个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内最上面添加一个

我们再到body内,需要出现点击后转到顶部位置添加,回到顶部

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


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


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

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









菜鸟教程

访问 {{myVar}} 学习!

该实例可以使用了原生的 href 属性,但在 AngularJS 中, ng-href 属性更安全。

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








// 为空不跳转

菜鸟教程

访问 {{myVar}}ggggggggggg 学习!

该实例可以使用了原生的 href 属性,但在 AngularJS 中, ng-href 属性更安全。

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

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

本文章参考博客地址

你可能感兴趣的:(阻止a跳转:a标签href属性 与 ng-href指令)