標籤href屬性與onclick事件

a標籤主要用來實現頁面跳轉,能夠經過href屬性實現,也能夠在onclick事件裏實現。javascript

<a onclick="window.location.href='www.cnblogs.com'" href="javascript:void(0);">博客園</a>

博客園java

這段代碼在主流瀏覽器裏都沒問題,但在IE6下會出現不能跳轉的問題。這到底是什麼緣由呢?瀏覽器

javascript:void(0);函數

void(arg);能夠理解爲永遠返回null的函數,可是其參數不能爲空。其參數能夠爲任意的表達式甚至函數。測試

<a href="javascript:void(name = '博客園'); alert(name);">測試</a>

測試spa

IE6先運行DOM自己綁定的事件,如onclick;若是沒有阻止冒泡,則會順序執行href屬性。而void(0);正是不須要執行任何事件,則IE6告訴瀏覽器不執行任何事件(覆蓋以前的動做),而且終止冒泡至關於return false;因而瀏覽器沒有執行任何動做。因此只要在onclick事件內阻止冒泡事件便可。code

<a onclick="window.location.href='http://www.cnblogs.com';return false;" href="javascript:void(0);">博客園</a>

博客園blog

這樣在IE6下就能夠正常運行了。事件

另外還有一種方法就是不使用javascript:void(0);而改使用#也能夠避免,href屬性內的#原本的意思就是錨點#name因此當不指定任何錨點時會到頁面頂端。#是有特定意義的,默認是#top,若是#後有內容會被認爲是一個標籤而從頁面找到相應標籤跳轉到該處,找不到會跳轉到頁首,若是不想讓跳轉,可使用###,###就是一個無心義的標籤指定。ip

相關文章
相關標籤/搜索