首頁 web前端 js教程 javascript:void(0)是什麼意思及href=#與href=javascriptvoid(0)的區別_javascript技巧

javascript:void(0)是什麼意思及href=#與href=javascriptvoid(0)的區別_javascript技巧

May 16, 2016 pm 03:32 PM

Javascript中void是一個運算符,該運算子指定要計算一個表達式但不傳回值。

void 運算子用法格式如下:

1. javascript:void (expression)

2. javascript:void expression

expression 是一個要計算的 Javascript 標準的表達式。表達式外側的圓括號是選的,但是寫上去是個好習慣。

你以使用 void 運算子指定超級連結。表達式會被計算但是不會當前文件處裝入任何內容。

範例-點選超連結不跳轉

1:

2:

3:

4:

點擊連結後,頁面會向上滾到頁首,# 預設錨點為#TOP(實際測試發現滾動條會滾到頂端)而以上四種方法僅表示一個死連結都表示是一個死連結不會跳轉也不會回到頂部.

範例-為什麼location.href不自動跳轉?

<a href="javascript:void(0)" onclick="delete('123')">删除</a>
function delete(id){
 if(confirm("确实要删除[为什么location.href不自动跳转?]吗?")) {
  location.href="/delete.jsp?id=" + id;
 }
}
登入後複製

以上程式碼不管如何檢查都沒有任何問題,而location.href="/delete.jsp?id=" id;在別的地方都好使,為什麼這段程式碼就行呢?

原因是那個void(0)把程式碼改成:

<a href="javascript:delete('123')">删除</a>function delete(id) {
 if(confirm("确实要删除[为什么location.href不自动跳转?]吗?")) {
  location.href="/delete.jsp?id=" + id;
 }
}
登入後複製

我們發現,頁面立即就跳轉了,能正常刪除對應的資料.為什麼呢?

因為void是一個操作符,會計算一個表達式,但不會回傳值,當然也不會改變目前頁面的任何內容,也就不會正常的跳躍.

說明

void 運算子對運算式求值,並傳回 undefined。在希望求表達式的值,但又不希望腳本的剩餘部分看見這個結果時,該運算子最有用。

連結(href)直接使用javascript:void(0)在IE中可能會引起一些問題,例如:造成gif動畫停止播放等,所以,最安全的方法還是使用「#」。為防止點擊連結後跳到頁首,onclick 事件 return false即可。

PS:href=#與href=javascriptvoid(0)的區別

#"包含了一個位置資訊 
預設的錨點是#top 也就是網頁的上端
而javascript:void(0)  只表示一個死連結 
這就是為什麼有的時候頁面很長瀏覽連結明明是#可是跳動到了頁首
而javascript:void(0)
則不是如此 所以呼叫腳本的時候最好用void(0)

等 

開啟新視窗連結的幾種方法

1.window.open('url')

2.用自訂函數       

<script>   
function openWin(tag,obj)   
{    
obj.target="_blank";    
obj.href = "Web/Substation/Substation.aspx?stationno="+tag;    
obj.click();   
}   
</script> 
<a href="javascript:void(0)" onclick="openWin(3,this)">LINK_TEST</a> 
window.location.href="" 
登入後複製

----------------------------------------------- --------------------------------  

如果是個# ,就會出現跳到頂端的情況,個人收藏的幾種解決方法:

1: 
2:
3:
4: 
5:(好像在FF中不能顯示)

----------------------------------------------- --------------------------------

以上內容是小編給大家介紹的javascript:void(0)是什麼意思及href=#與href=javascriptvoid(0)的區別,希望對大家有所幫助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

在JavaScript中替換字符串字符 在JavaScript中替換字符串字符 Mar 11, 2025 am 12:07 AM

在JavaScript中替換字符串字符

自定義Google搜索API設置教程 自定義Google搜索API設置教程 Mar 04, 2025 am 01:06 AM

自定義Google搜索API設置教程

示例顏色json文件 示例顏色json文件 Mar 03, 2025 am 12:35 AM

示例顏色json文件

8令人驚嘆的jQuery頁面佈局插件 8令人驚嘆的jQuery頁面佈局插件 Mar 06, 2025 am 12:48 AM

8令人驚嘆的jQuery頁面佈局插件

構建您自己的Ajax Web應用程序 構建您自己的Ajax Web應用程序 Mar 09, 2025 am 12:11 AM

構建您自己的Ajax Web應用程序

什麼是這個'在JavaScript? 什麼是這個'在JavaScript? Mar 04, 2025 am 01:15 AM

什麼是這個'在JavaScript?

通過來源查看器提高您的jQuery知識 通過來源查看器提高您的jQuery知識 Mar 05, 2025 am 12:54 AM

通過來源查看器提高您的jQuery知識

10張移動秘籍用於移動開發 10張移動秘籍用於移動開發 Mar 05, 2025 am 12:43 AM

10張移動秘籍用於移動開發

See all articles