代碼,<a href="#" onclick="javascript:getadd();">,雖然用getadd()函數實現的id="book"的div輸出內容,這個是局部的核心技巧之一,但是因為href="#"這個元素會讓頁面自動跳到頂端,感覺很不爽。因為這樣頁面會跳動一下,所以局部重新整理那種體驗不強。
於是將#去掉,剩下 href="",發現這樣也不行,這個會使整個頁面載入後還要再重新整理一次。
最後看到別人的代碼,得到瞭解決方法,<a href="javascript:void(0)">。
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操作。那什麼情況下用void(0)比較多呢,無重新整理,當然是Ajax了,看一下Ajax的web頁面的話,一般都會看到有很多的void(0),:) ,所以在使用void(0)之前,最好先想一想,這個頁面是否需要整體重新整理