Nodejs中的this詳解
以下內(nèi)容都是關(guān)于在nodejs中的this而非javascript中的this,nodejs中的this和在瀏覽器中javascript中的this是不一樣的。
在全局中的this
console.log(this); {} this.num = 10; console.log(this.num); 10 console.log(global.num); undefined
全局中的this默認是一個空對象。并且在全局中this與global對象沒有任何的關(guān)系,那么全局中的this究竟指向的是誰?在本章節(jié)后半部分我們會講解。
在函數(shù)中的this
function fn(){ this.num = 10; } fn(); console.log(this); {} console.log(this.num); undefined console.log(global.num); 10
在函數(shù)中this指向的是global對象,和全局中的this不是同一個對象,簡單來說,你在函數(shù)中通過this定義的變量就是相當于給global添加了一個屬性,此時與全局中的this已經(jīng)沒有關(guān)系了。
如果不相信,看下面這段代碼可以證明。
function fn(){ function fn2(){ this.age = 18; } fn2(); console.log(this); global console.log(this.age); 18 console.log(global.age); 18 } fn();
對吧,在函數(shù)中this指向的是global。
構(gòu)造函數(shù)中的this
function Fn(){ this.num = 998; } var fn = new Fn(); console.log(fn.num); 998 console.log(global.num); undefined
在構(gòu)造函數(shù)中this指向的是它的實例,而不是global。
我們現(xiàn)在可以聊聊關(guān)于全局中的this了,說到全局中的this,其實和Nodejs中的作用域有一些關(guān)系,如果你想了解Nodejs中關(guān)于作用域的信息可以看探討Nodejs中的作用域問題。這篇文章。
回到正題,全局中的this指向的是module.exports。
this.num = 10; console.log(module.exports); {num:10} console.log(module.exports.num);
為什么在全局中this會指向module.exports,那就需要先了解更多關(guān)于module.exports的相關(guān)知識了,暫時我們先了解到這里,后面有機會我們會聊到module
相關(guān)文章
koa2 用戶注冊、登錄校驗與加鹽加密的實現(xiàn)方法
這篇文章主要介紹了koa2 用戶注冊、登錄校驗與加鹽加密的實現(xiàn)方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-07-07express搭建的nodejs項目使用webpack進行壓縮打包
對于打包這個問題它并不是難點,但是對于我們這種初學者來說,根本就不知道應(yīng)該怎么做,下面這篇文章主要給大家介紹了關(guān)于express搭建的nodejs項目使用webpack進行壓縮打包的相關(guān)資料,需要的朋友可以參考下2022-12-12Node.js實現(xiàn)在目錄中查找某個字符串及所在文件
這篇文章主要介紹了Node.js實現(xiàn)在目錄中查找某個字符串及所在文件,文中代碼簡潔,而且速度相當?shù)目?需要的朋友可以參考下2014-09-09