JavaScript void 運算符詳解
JavaScript void 運算符
void定義:
void 運算符對給定的表達式進行求值,然后返回undefined。void是一個一元運算符,接受單個操作數(shù),可以是任何類型,返回一個 undefined。
void語法:
void 在表達式的左邊,void 右邊的表達式可以是帶括號形式(例如:void(0)),也可以是不帶括號的形式(例如:void 0)。
void作用:
當(dāng)我們只需要評估一個表達式而不是返回其值時,void關(guān)鍵字的重要性就發(fā)揮出來了。這意味著,通過使用它,我們可以阻止瀏覽器顯示表達式執(zhí)行的結(jié)果。
我們在阻止a標(biāo)簽的默認行為時候就使用到void
<a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ></a> <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" > 這個鏈接點擊之后不會做任何事情,如果去掉 void(), 點擊之后整個頁面會被替換成一個字符 0。 </a>
立即調(diào)用的函數(shù)表達式
在使用立即執(zhí)行的函數(shù)表達式時,可以使用void運算符讓js引擎吧一個function關(guān)鍵字識別成函數(shù)表達式而不是函數(shù)聲明
無
有void:
在一些箭頭函數(shù)中,若此函數(shù)沒有對應(yīng)的返回值,可能會造成一些不可預(yù)估的問題,安全起見,對沒有返回的函數(shù),可以在前面加上void
var fos = () => { return void bar() } fos()
為什么要使用void
void和undefined有什么區(qū)別:
undefined屬于基礎(chǔ)類型且還是全局類型,全局類型還可以被更改、被賦值。
void屬于運算符,運算符只能被求值計算,不能被賦值更改。
所以在安全層面上來說 void比undefined更安全。所以在源碼中一般都是使用void xx這種方式來獲取undefined,比直接使用undefined來的更加安全可靠。
如:
export default function isUndefined(input) { return input === void 0; }
JavaScript:void(0) 用法及常見問題解析
javascript:void(0); 是一種在JavaScript和網(wǎng)頁開發(fā)中經(jīng)常使用的技術(shù),尤其在處理鏈接的行為時。本文將深入探討 javascript:void(0); 的用法,以及在使用過程中可能遇到的常見問題和解決方法。
什么是 javascript:void(0);?
javascript:void(0); 是一個JavaScript表達式,用于防止鏈接在被點擊時執(zhí)行其默認行為(即導(dǎo)航到一個新頁面)。void 是一個運算符,用于執(zhí)行一個表達式但不返回任何值。
為什么使用 javascript:void(0);?
在HTML中,<a>
標(biāo)簽通常用于創(chuàng)建鏈接。如果不希望點擊鏈接時頁面跳轉(zhuǎn)到其他頁面或重新加載當(dāng)前頁面,可以使用 javascript:void(0);。這樣,鏈接會保持在當(dāng)前頁面,同時可以通過JavaScript添加其他功能,如觸發(fā)彈窗、開啟模態(tài)框等。
使用示例
以下是一個簡單的示例,展示如何使用 javascript:void(0); 來防止鏈接默認行為:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>JavaScript:void(0) 示例</title> </head> <body> <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="alert('Hello, world!')">點擊我</a> <script> // JavaScript 代碼可以放在這里 </script> </body> </html>
在這個例子中,點擊鏈接會彈出一個對話框,而不是跳轉(zhuǎn)到另一個頁面或重新加載當(dāng)前頁面。
常見問題及解決方法
使用 javascript:void(0); 與 # 的區(qū)別
javascript:void(0); 完全阻止鏈接的默認行為,而 # 會改變URL(添加 # 到URL末尾),可能導(dǎo)致頁面滾動到頂部。
在實際應(yīng)用中,推薦使用 javascript:void(0); 來避免這種行為,尤其是在單頁應(yīng)用(SPA)中,這可以防止不必要的滾動行為和歷史記錄變動。
無法觸發(fā)鏈接的點擊事件
如果發(fā)現(xiàn) javascript:void(0); 阻止了鏈接的點擊事件,確保JavaScript事件處理器正確綁定。在現(xiàn)代JavaScript開發(fā)中,推薦使用事件監(jiān)聽器來代替 onclick 屬性,例如:
<a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" id="myLink">點擊我</a> <script> document.getElementById('myLink').addEventListener('click', function() { alert('Hello, world!'); }); </script>
無法通過鍵盤訪問
javascript:void(0); 鏈接可能會導(dǎo)致無法通過鍵盤訪問,這對于保持網(wǎng)站的無障礙性是一個問題。為了改進無障礙性,確保鏈接或按鈕可以通過鍵盤(通常是 Tab 鍵和 Enter 鍵)訪問,并適當(dāng)使用 role 和 tabindex 屬性。
結(jié)論
javascript:void(0); 是一個有用的技巧,可以在不跳轉(zhuǎn)頁面的情況下觸發(fā)鏈接的點擊事件。然而,在使用時需要注意提高網(wǎng)站的無障礙性,并確保不影響用戶體驗。理解 javascript:void(0); 的行為和限制可以幫助開發(fā)者更有效地使用這一技術(shù)。
到此這篇關(guān)于JavaScript void 運算符的文章就介紹到這了,更多相關(guān)JavaScript void 運算符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
layui 對table中的數(shù)據(jù)進行轉(zhuǎn)義的實例
今天小編就為大家分享一篇layui 對table中的數(shù)據(jù)進行轉(zhuǎn)義的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09TypeScript?Pinia實戰(zhàn)分享(Vuex和Pinia對比梳理總結(jié))
這篇文章主要介紹了TypeScript?Pinia實戰(zhàn)分享(Vuex和Pinia對比梳理總結(jié)),今天我們再來實戰(zhàn)下官方推薦的新的vue狀態(tài)管理工具Pini,感興趣的小伙伴可以參考一下2022-06-06