我们都知道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的源码。
网友评论