摘要:想想也是難以置信,這應該全歸功于對框架的依賴,促使助長了自己對學習的懈怠。真正的成了離職就失業的尷尬境地。我們接下來來了解下中的的使用和作用。以前對中的理解很簡單粗暴誰調用就指向誰。如果例題中有不對的地方希望予以指教留言評論
前言
使用JavaScript有很長一段時間了,但是以前過多都是使用,從不去及理解其中原理,單單只是去生拼硬湊。這樣的開發居然做了2年。匪夷所思居然項目中JavaScript的使用還沒有遇到過越不過的坎。想想也是難以置信,這應該全歸功于對框架的依賴,促使助長了自己對學習JavaScript的懈怠。直到最近找工作才發現感覺自己被框架掏空,對源生的JavaScript感到陌生,很基本的試題都覺得答不上來。真正的成了‘離職就失業的尷尬境地’。對此我就不多說了,畢竟發現問題算及時,所以下定決心去真正從零開始了解JavaScript這門語言。夯實好基礎是對一個開發人員最基本的要求,如果想走的更遠。這是一條長征之路。
我們接下來來了解下JavaScript中的this的使用和作用。以前對JavaScript中this的理解很簡單粗暴:‘this’誰調用就指向誰。原理就這么一句但要搞到透徹還是有一定難度的,在一次筆試中就搞得很狼狽。
接下來我將用寫代碼片段來解釋this的使用和功能
第一種 常態下的this
var num1 = 11; var num2 = 66; function fn1(num,num1){ var funmber = "我是fn1的孩子!你管不到我??!" num = 100; num1 = 200; num2 = 300; console.log(funmber)// 我是fn1的孩子!你管不到我??! console.log(this.funmber)// undefiined (為什么會返回undefined呢? // 原因就是當函數內部調用全局未定義的變量時候, // this會私自定義一個funmu變量為全局變量, // 并付默認值就是undefined)。 console.log("num1") console.log(num1)// 200 此時的num1就等于函數內的這個num1的值 console.log(this.num1)// 11 (num1作為參數傳進來后, // 初始值var num1 = 11覆蓋了num1 = 200) console.log("num2") console.log(num2)//300 console.log(this.num2)// 300 (函數體內變量沒有var定義視為全局變量, // 所以this時相當于重新對num2賦值300覆蓋了66) console.log("num") console.log(num)//100 此時的num當前的值就是自己 console.log(this.num)// undefiined (為什么會返回undefined呢? // 原因就是當函數內部調用全局未定義的變量時候, // this會私自定義一個num變量為全局變量, // 并付默認值就是undefined)。 } fn1(); console.log(num2)// 300 (函數體內變量沒有var定義視為全局變量, // 所以this時300覆蓋了66) console.log(this.num2)// 300 console.log(this.num)// undefined console.log(funmber) // 由于作用域的關系,內部可以訪問外部,外部正常情況下不能訪問內部形成閉包 // 外部并未找到funmu的定義 , // 打印funmu is not defined(這句報錯下邊那句就不可能在執行了) console.log(num)// 外部并未找到num的定義,會打印 num is not defined
第二種 常態下的this對象和new新的對象下的this
var age = 27; var obj = { age:30, say: function(){ console.log(this.age) } } obj.say();//30 (此時的this.age指向在本obj對象ao中查找所以值為30) var func = obj.say;//(把obj.say這個方法提出來付給func, //func是全局函數所以this指向就是全局變量) func();//27 ( 執行這個方法后原本obj.say里的方法體付給func, // func無法訪問obj里面面的ao。所以他會向上找全局變量個var age = 27) var foo = "123" function aa(){ var foo = "321" this.foo = "456" console.log(foo)//console里面這個foo指的是aa(){}這個自身內的foo //this.foo指的是var foo = ‘123’這個變量。若打印this.foo則輸出‘456’ //原因是初始化值被覆蓋掉了 } aa() var foo = "321" function pints(){ this.foo = "123" console.log(foo)//console里面的foo是全局變量var foo = 321 這個, //pints()里面沒有變量foo,因為沒有聲明, //this.foo指的是var foo=321 //當前值123覆蓋了foo原聲明時的值321所以打印123 } pints() var foo = "123" function test(){ this.foo = "654" console.log(foo) } new test()//new一個test()后,不能讀到之前的test()里面的foo,只能讀取全局的foo
第三種 常態下的this對象和new新的對象下的this
// 箭頭函數里的前頭函數指向上級作用域 var age = 26; var obj = { age:32, say:()=> {//箭頭函數指向是上級作用域 console.log(this.age) console.log(age) } } obj.say()//都是26 //方法中的方法 var age = 26; function Person(){ this.age = 22; // var age = 18; let say = () => { // var age = 19; console.log(this.age) // 22 此時的this.age指向上級作用域中的var age = 26; // 執行函數預編譯后this.age的值覆蓋age的初始值 function fu(){ console.log(age) // 26 此時打印的是全局變量的初始值,這時的age在Person中沒有找到age, // 會再向上搜索所以找到了age=26 } fu(); } say(); } var x = new Person() //22 new等同于Person()的命令
差不多就這些情況了,希望通過這些例子能夠幫助大家理解this對象。如果例題中有不對的地方希望予以指教留言評論!!!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/106794.html
摘要:理解的函數基礎要搞好深入淺出原型使用原型模型,雖然這經常被當作缺點提及,但是只要善于運用,其實基于原型的繼承模型比傳統的類繼承還要強大。中文指南基本操作指南二繼續熟悉的幾對方法,包括,,。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。 怎樣使用 this 因為本人屬于偽前端,因此文中只看懂了 8 成左右,希望能夠給大家帶來幫助....(據說是阿里的前端妹子寫的) this 的值到底...
摘要:在中,當使用關鍵字調用函數構造函數時,函數構造函數中也有這個概念,但是它不是惟一的規則,而且常常可以引用來自不同執行上下文的不同對象。因此,我們使用調用函數,可以看到這是對象,并且的屬性是正常的。 一直以來,javascript里邊的this都是一個很難理解的東西,之前看的最多的就是阮一峰老師關于this的理解: http://www.ruanyifeng.com/blo... htt...
摘要:當中的是一個用于指向當前上下文對象的關鍵字。創建實例時的構造函數中的,永遠指向那個實例后對象,不是外部環境使用來調用函數時,先改變其上下文環境,在對其構造函數進行調用。 javascript 當中的 this是一個用于指向當前上下文對象的關鍵字。在面向對象編程及日常開發當中我們經常與其打交道,初學javscript的朋友非常容易誤入歧途從而理解錯誤。 上下文對象概念 在我的深入貫徹閉包...
摘要:關于中的指向我上的菜鳥倉庫地址點擊跳轉查看其他相關文章文章在我的博客上的地址點擊跳轉學習,必不可少的肯定要理解的指向。 關于javascript中this的指向 我GitHub上的菜鳥倉庫地址: 點擊跳轉查看其他相關文章 文章在我的博客上的地址: 點擊跳轉 ? ? ? ? 學習javascript,必不可少的肯定要理解this的指向。要學習this指向之前,就要先理解了我前面寫的幾...
摘要:回調函數在回調函數中的指向也會發生變化。在閉包回調函數賦值等場景下我們都可以利用來改變的指向,以達到我們的預期。文章參考系列文章理解閉包理解執行棧理解作用域理解數據類型與變量原文發布在我的公眾號,點擊查看。 這是本系列的第 5 篇文章。 還記得上一篇文章中的閉包嗎?點擊查看文章 理解 JavaScript 閉包 。 在聊 this 之前,先來復習一下閉包: var name = Nei...
閱讀 1379·2023-04-25 18:34
閱讀 3437·2021-11-19 09:40
閱讀 2824·2021-11-17 09:33
閱讀 2935·2021-11-12 10:36
閱讀 2823·2021-09-26 09:55
閱讀 2653·2021-08-05 10:03
閱讀 2512·2019-08-30 15:54
閱讀 2861·2019-08-30 15:54