JavaScript中直接寫undefined的錯(cuò)誤及用法剖析
介紹
眾所周知,在JavaScript 語(yǔ)言中,一個(gè)沒(méi)有被賦值的變量會(huì)有個(gè)默認(rèn)值 undefined ,而 undefined 作為全局對(duì)象的一個(gè)屬性經(jīng)常會(huì)用作一些賦值返回,邏輯判斷等業(yè)務(wù)場(chǎng)景中??杀酒谝f(shuō)的是,盡量不要直接去拼寫 undefined 了,因?yàn)槟鞘遣惶珖?yán)謹(jǐn)?shù)男袨?,可能出現(xiàn)很多意外情況。
原因
我們經(jīng)常在判斷某個(gè)變量是否等于 undefined ,如下:
function test(value) {
if (value === undefined) {
return `value is undefined`;
}
return `value is not undefined`;
}
let value;
test(value); // 'value is undefined'
這樣看上去沒(méi)有什么毛病,而且 window.undefined 的 writable 為 false 這意味著它是只讀的沒(méi)發(fā)寫入修改,你在 window 下,修改 undefined 也是無(wú)濟(jì)于事。
undefined = "hello world"; console.log(undefined); // undefined
對(duì)這樣是沒(méi)錯(cuò),看似萬(wàn)無(wú)一失。但是還有一種情況沒(méi)有考慮到,那就是 undefined 它是 window 對(duì)象的一個(gè)全局屬性,那么我們可以局部也起一個(gè)也叫 undefined 的變量給它賦值,那么問(wèn)題就來(lái)了。如下:
function test(value) {
let undefined = "hello world";
if (value === undefined) {
return `value is undefined`;
}
return `value is not undefined`;
}
let value;
test(value); // 'value is not undefined'
我們可以看到驗(yàn)證入?yún)⑹欠袷?undefined 的方法就出現(xiàn)了bug。因?yàn)?,我們?undefined 賦了一個(gè)新值,在這個(gè)作用域下找到的所有 undefined 都是那個(gè)新的值,這樣我們就沒(méi)法通過(guò)這種方式去驗(yàn)證判斷 undefined 了。
解決
不賣關(guān)子了,我們通常會(huì)用 void 0 或者 void(0) 來(lái)去直接替代 undefined ,因?yàn)樗祷氐囊彩?undefined 。
function test(value) {
let undefined = "hello world";
if (value === void 0) {
return `value is undefined`;
}
return `value is not undefined`;
}
let value;
test(value); // 'value is undefined'
void 運(yùn)算符是對(duì)給定的表達(dá)式進(jìn)行求值,然后返回 undefined 。而且, void 是不能重新定義的,不然會(huì)報(bào)語(yǔ)法錯(cuò)誤,這樣也保證了用 void 來(lái)代替 undefined 的不會(huì)出現(xiàn)被重定義而造成的bug。
function func() {
var void = function() {};
return void(0);
}
// Uncaught SyntaxError: Unexpected token 'void'
結(jié)語(yǔ)
其實(shí)在很早之前,很多大廠的前端規(guī)范都會(huì)寫到用 void 0 去代替 undefined 作為準(zhǔn)則,去防止一些意外發(fā)生。對(duì)于大型項(xiàng)目來(lái)說(shuō),這點(diǎn)嚴(yán)謹(jǐn)也是值得考慮的。 PS:隨著前端工程化的推進(jìn),打包和校驗(yàn)時(shí)都會(huì)規(guī)避掉這個(gè)問(wèn)題,但我們依然要認(rèn)識(shí)到這個(gè)寫法背后的原因,養(yǎng)成習(xí)慣,雖然后面遇到的可能性概率幾乎為0。
以上就是不要在JavaScript中直接寫undefined了的詳細(xì)內(nèi)容,更多關(guān)于JavaScript undefined的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JavaScript+HTML實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)
這篇文章主要介紹了JavaScript實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)js的小伙伴們有一定的幫助,需要的朋友可以參考下2021-04-04
實(shí)現(xiàn)基于飛書webhook監(jiān)聽(tīng)github代碼提交
這篇文章主要為大家介紹了實(shí)現(xiàn)基于飛書webhook監(jiān)聽(tīng)github代碼提交示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
微信小程序 wxapp內(nèi)容組件 text詳細(xì)介紹
這篇文章主要介紹了微信小程序 wxapp內(nèi)容組件 text詳細(xì)介紹的相關(guān)資料,并附簡(jiǎn)單實(shí)例代碼,需要的朋友可以參考下2016-10-10
跨端開(kāi)發(fā)框架avm組件封裝經(jīng)驗(yàn)分享
這篇文章主要為大家介紹了跨端開(kāi)發(fā)框架avm組件封裝的經(jīng)驗(yàn)分享,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
微信小程序開(kāi)發(fā)之Tabbar實(shí)例詳解
這篇文章主要介紹了微信小程序開(kāi)發(fā)之Tabbar實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-01-01
JavaScript原型鏈中函數(shù)和對(duì)象的理解
這篇文章主要為大家介紹了JavaScript原型鏈中函數(shù)和對(duì)象的理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
await vs return vs return await關(guān)鍵區(qū)別
這篇文章主要為大家介紹了await vs return vs return await關(guān)鍵區(qū)別解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12

