1. 程式人生 > >javascript:void(0)與# 我所遇到了問題

javascript:void(0)與# 我所遇到了問題

剛好把專案的大體完善了。現在回想一下之前我所遇到的一些細節問題,特別是花費了我很多時間。(以下的例子在我的member.jsp和member.js)

一個是我對記錄進行刪除的時候,頁面沒有重新整理 第二個是:我對於登出登入進行操作的時候,頁面沒有重新整理(註明:登出登入在火狐,谷歌,ie8正常,但是在ie6失敗).後來發現問題都與 javascript:void(0),#之間的區別有關。

於是我開始在網上搜索一番檢視兩者之間的區別:

"#"包含了一個位置資訊 預設的錨點是#top 也就是網頁的上端
<a href="#"> 點選連結後,頁面會向上滾到頁首,# 預設錨點為 #TOP(實際測試發現 滾動條會滾到頂端)
而javascript:void(0) 僅僅表示一個死連結,例如:<a href="javascript:void(0)" > 點選連結後,頁面不動。
<a href="#" onclick="javascript:return false;"> 作用同上。
點選連結後,不想使頁面滾到頁首(頂部),就用href="javascript:void(0)",不要用href="#"
如果是個# ,就會出現跳到頂部的情況,收藏的幾種解決方法(保持頁面不會到頂端的方法):
1:<a href="####"></a>
2:<a href="javascript:void(0)"></a>
3:<a href="javascript:void(null)"></a>
4:<a href="#" onclick="return false"></a>

下面是我測試的一個例子:

<a href="#" onClick="del(${member.memberId});return false;"><img src="<%=ctxPath%>/image/admin/btn_delete.gif"/>刪除</a>  注意這裡面加了一句,作用在於 當彈出confirm對話方塊的時候 我單擊取消的時候 頁面不動,如果不加的話,單擊取消操作,滾動條會向頂端滾動。

JavaScript中void(0)的含義:
JavaScript中void是一個操作符,該操作符指定要計算一個表示式但是不返回值。
void 操作符用法格式如下:
1. javascript:void (expression)
2. javascript:void expression
expression是一個要計算的 JavaScript 標準的表示式。表示式外側的圓括號是可選的,但是寫上去是一個好習慣。我們可以使用 void 操作符指定超級連結。表示式會被計算但是不會在當

前文件處裝入任何內容。面的程式碼建立了一個超級連結,當用戶點選以後不會發生任何事。當用戶點選連結時,void(0) 計算為 0,但在 JavaScript 上沒有任何效果。
<a href="javascript:void(0)">單擊此處什麼也不會發生</a>
也就是說,要執行某些處理,但是不整體重新整理頁面的情況下,可以使用void(0),但是在需要對頁面進行refresh的情況下,那就要仔細了。 我們可以這樣用<a href="javascript:void(document.form.submit())">,這句話會進行一次submit操作,使頁面refresh。像我們一般的記錄的修改,刪除等等  需要頁面相應的重新整理!

我的例子:

  <a href="javascript:void(document.mainForm.submit())" onClick="del(${member.memberId});"><img src="<%=ctxPath%>/image/admin/btn_delete.gif"/>刪除</a>
這樣一個document.mainForm.submit()  代替了 jsp頁面中js檔案的$("#mainForm").submit();使得頁面重新整理了。
   那什麼情況下用void(0)比較多呢,無重新整理,當然是Ajax了,看一下Ajax的web頁面的話,一般都會看到有很多的void(0),:),所以在使用void(0)之前,最好先想一想,這個頁面是否需要

相應的重新整理。

下面是我在網上搜索的一個與我登出登入遇到相似的問題,先看他的說法:

 為什麼location.href不自動跳轉?慎用javascript:void(0)
<a href="javascript:void(0)" onclick="delete('123')">刪除</a>
<script>
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>
<script>
function delete(id) {
   if(confirm("確實要刪除[為什麼location.href不自動跳轉?]嗎?")) {
       location.href="/delete.jsp?id=" + id;
   }
}

我的登出登入最終的解決方法:

我的登出登入:
decorator.jsp
<li><a href="#" onClick="logout()">登出</a></li>
對應的js檔案
function logout(){
  if(confirm("確定要退出管理後臺系統嗎?"))          
   parent.window.location= ctxPath+"/console/logout.do"; 
 }
可以成功登出登入。
按照上面的方法:
decorator.jsp
 <li><a href="javascript:logout()">登出</a></li>
對應的js檔案
function logout(){
  if(confirm("確定要退出管理後臺系統嗎?"))          
   parent.window.location= ctxPath+"/console/logout.do"; 
 }
也可以可以成功登出登入。
但是如果我的jsp頁面換成<li><a href="javascript:void(0);" onClick="logout()">登出</a></li>
對應的js檔案
function logout(){
  if(confirm("確定要退出管理後臺系統嗎?"))          
   parent.window.location= ctxPath+"/console/logout.do"; //這裡我在在logoutAction中把session值清空 然後在struts中配置跳轉的路徑/login.jsp
 }
登出失敗,頁面不能正常的跳轉。必須再次重新整理頁面,才可以。

可以看出想要頁面進行重新整理  javascript:void(0)真的是慎用!

我的刪除操作也是和上面一樣 。源於javascript:void(0)  我的頁面刪除後 同樣要對頁面記錄進行重新整理!

改成了<a href="#" onClick="del(${member.memberId});"><img src="<%=ctxPath%>/image/admin/btn_delete.gif"/>刪除</a>這樣才可以。或者 <a href="javascript:void(document.mainForm.submit())" onClick="del(${member.memberId});"><img src="<%=ctxPath%>/image/admin/btn_delete.gif"/>刪除</a>(這時把相應的js中的 $("#mainForm").submit();註釋掉了)

效果達到額!