熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Java編程 >> JSP教程 >> 正文

href=#與href=nojavascript...void(0)的區別

2013-11-15 12:11:31  來源: JSP教程 

  "#"包含了一個位置信息

  默認的錨點是#top 也就是網頁的上端
而javascript:void() 僅僅表示一個死鏈接
這就是為什麼有的時候頁面很長浏覽鏈接明明是#可是跳動到了頁首
而Javascript:void() 則不是如此
所以調用腳本的時候最好用void()
或者<input onclick>
<div onclick>等
打開新窗口鏈接的幾種辦法
windowopen(url)
用自定義函數
        <script>
        function openWin(tagobj)
        {
            objtarget="_blank";
            objhref = "Web/Substation/Substationaspx?stationno="+tag;
            objclick();
        }
        </script>
<a href="javascript:void()" onclick="openWin(this)">LINK_TEST</a>
windowlocationhref=""

如果是個# 就會出現跳到頂部的情況個人收藏的幾種解決方法
<a href="####"></a>
<a href="javascript:void()"></a>
<a href="javascript:void(null)"></a>
<a href="#" onclick="return false"></a>
<span style="cursor:hand"></span>(好像在FF中不能顯示)

慎用JavaScript:void()
今天調試CGI的時候明明CGI程序已經執行並且最後結果也是正確的但是頁面就是不刷新在Firefox下測試結果卻是正常的IE卻偏偏不刷新!仔細調查了一下發現cgi頁面鏈接的是 <a href="javaScript:void()" OnClick="XXX_Func();" …> only a sample </a>問題就出在這個void()上!讓我們先來看看JavaScript中void()的含義:
JavaScript中void是一個操作符該操作符指定要計算一個表達式但是不返回值
void 操作符用法格式如下
javascript:void (exPRession)
javascript:void expression
expression是一個要計算的 JavaScript 標准的表達式表達式外側的圓括號是可選的但是寫上去是一個好習慣我們可以使用 void 操作符指定超級鏈接表達式會被計算但是不會在當前文檔處裝入任何內容面的代碼創建了一個超級鏈接當用戶點擊以後不會發生任何事當用戶點擊鏈接時void() 計算為 但在 JavaScript 上沒有任何效果
<a href="javascript:void()">單擊此處什麼也不會發生</a>
也就是說要執行某些處理但是不整體刷新頁面的情況下可以使用void()但是在需要對頁面進行refresh的情況下那就要仔細了
其實我們可以這樣用<a href="javascript:void(documentformsubmit())">這句話會進行一次submit操作那什麼情況下用void()比較多呢無刷新當然是Ajax了看一下Ajax的web頁面的話一般都會看到有很多的void()) 所以在使用void()之前最好先想一想這個頁面是否需要整體刷新

  為什麼locationhref不自動跳轉?慎用javascript:void()

  <a href="javascript:void()" onclick="delete()">刪除</a>
<script>
function delete(id) {
   if(confirm("確實要刪除[為什麼locationhref不自動跳轉?]嗎?")) {
       locationhref="/deletejsp?id=" + id;
   }
}
以上代碼不管如何檢查都沒有任何問題而locationhref="/deletejsp?id=" + id;在別的地方都好使為什麼這段代碼就行呢?
原因是那個void()把代碼改成
<a href="javascript:delete()">刪除</a>
<script>
function delete(id) {
   if(confirm("確實要刪除[為什麼locationhref不自動跳轉?]嗎?")) {
       locationhref="/deletejsp?id=" + id;
   }
}
我們發現頁面立即就跳轉了能正常刪除相應的數據

  void是一個操作符會計算一個表達式但不會返回值當然也不會改變當前頁面的任何內容也就不會正常的跳轉


From:http://tw.wingwit.com/Article/program/Java/JSP/201311/20468.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.