美文网首页
阻止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