点击一个超链接,怎么获取到它的url呢?
分析一下这个问题点击一个超链接,怎么获取到它的url呢
首先,需要获取信息,应当先保证其不跳转,即点击a标签时如何阻止其自动跳转到href的动作
获取url,即获取href属性的值
上面诸位同志回答2部分的都很好,但是都没处理自动跳转的问题
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>文档标题</title>
</head>
<body>
<!-- some other code -->
<a id='showHref' href="http://www.baidu.com">baidu</a>
</body>
</html>
假设是阻止特定标签的跳转,就不进行全体a标签的遍历了
<script type="text/javascript">
function init() {
document.getElementById('showHref').onclick = function() {
console.log(this.href);
/*下面两种写法任选其一*/
// return false;
event.preventDefault();
};
}
</script>
<script type="text/javascript">
$(document).on('click','#showHref',function() {
console.log(this.href);
/*或者*/
// console.log($('#showHref').attr('href'));
/*下面两种写法任选其一*/
// return false;
event.preventDefault();
});
</script>
@ 莲_涳栢__ 写的很好了,我这里再整合一下jquery的写法
<script type="text/javascript">
function init() {
Array.prototype.forEach.call(document.getElementsByTagName('a'), function(dom) {
dom.onclick = function() {
console.log(this.href);
/*下面两种写法任选其一*/
// return false;
event.preventDefault();
};
});
}
</script>
<script type="text/javascript">
$(document).on('click','a',function() {
console.log(this.href);
/*或者*/
// console.log($('#showHref').attr('href'));
/*下面两种写法任选其一*/
// return false;
event.preventDefault();
});
</script>
document.querySelectorAll()
比getElement(s)
系列有更好的兼容性,而且写法更统一,建议使用。当然IE6那种古董好像也是无法兼容的┑( ̄Д  ̄)┍