成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

關(guān)于JavaScript中this的理解

lindroid / 1135人閱讀

摘要:想想也是難以置信,這應(yīng)該全歸功于對(duì)框架的依賴,促使助長了自己對(duì)學(xué)習(xí)的懈怠。真正的成了離職就失業(yè)的尷尬境地。我們接下來來了解下中的的使用和作用。以前對(duì)中的理解很簡(jiǎn)單粗暴誰調(diào)用就指向誰。如果例題中有不對(duì)的地方希望予以指教留言評(píng)論

前言

使用JavaScript有很長一段時(shí)間了,但是以前過多都是使用,從不去及理解其中原理,單單只是去生拼硬湊。這樣的開發(fā)居然做了2年。匪夷所思居然項(xiàng)目中JavaScript的使用還沒有遇到過越不過的坎。想想也是難以置信,這應(yīng)該全歸功于對(duì)框架的依賴,促使助長了自己對(duì)學(xué)習(xí)JavaScript的懈怠。直到最近找工作才發(fā)現(xiàn)感覺自己被框架掏空,對(duì)源生的JavaScript感到陌生,很基本的試題都覺得答不上來。真正的成了‘離職就失業(yè)的尷尬境地’。對(duì)此我就不多說了,畢竟發(fā)現(xiàn)問題算及時(shí),所以下定決心去真正從零開始了解JavaScript這門語言。夯實(shí)好基礎(chǔ)是對(duì)一個(gè)開發(fā)人員最基本的要求,如果想走的更遠(yuǎn)。這是一條長征之路。

我們接下來來了解下JavaScript中的this的使用和作用。以前對(duì)JavaScript中this的理解很簡(jiǎn)單粗暴:‘this’誰調(diào)用就指向誰。原理就這么一句但要搞到透徹還是有一定難度的,在一次筆試中就搞得很狼狽。

接下來我將用寫代碼片段來解釋this的使用和功能

第一種 常態(tài)下的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 (為什么會(huì)返回undefined呢?
                                // 原因就是當(dāng)函數(shù)內(nèi)部調(diào)用全局未定義的變量時(shí)候,
                               // this會(huì)私自定義一個(gè)funmu變量為全局變量,
                              // 并付默認(rèn)值就是undefined)。
            
            
            console.log("num1")
            console.log(num1)// 200  此時(shí)的num1就等于函數(shù)內(nèi)的這個(gè)num1的值
            console.log(this.num1)// 11 (num1作為參數(shù)傳進(jìn)來后,
                                 // 初始值var num1 = 11覆蓋了num1 = 200)

            console.log("num2")
            console.log(num2)//300
            console.log(this.num2)// 300 (函數(shù)體內(nèi)變量沒有var定義視為全局變量,
                                 // 所以this時(shí)相當(dāng)于重新對(duì)num2賦值300覆蓋了66)
            
            console.log("num")
            console.log(num)//100  此時(shí)的num當(dāng)前的值就是自己
            console.log(this.num)// undefiined (為什么會(huì)返回undefined呢?
                                // 原因就是當(dāng)函數(shù)內(nèi)部調(diào)用全局未定義的變量時(shí)候,
                               // this會(huì)私自定義一個(gè)num變量為全局變量,
                              // 并付默認(rèn)值就是undefined)。
        }
        fn1();
        console.log(num2)// 300 (函數(shù)體內(nèi)變量沒有var定義視為全局變量,
                        //    所以this時(shí)300覆蓋了66)
                        
        console.log(this.num2)// 300
    
        console.log(this.num)// undefined
        
        console.log(funmber) // 由于作用域的關(guān)系,內(nèi)部可以訪問外部,外部正常情況下不能訪問內(nèi)部形成閉包
                            // 外部并未找到funmu的定義 ,
                           // 打印funmu is not defined(這句報(bào)錯(cuò)下邊那句就不可能在執(zhí)行了)
                         
        console.log(num)// 外部并未找到num的定義,會(huì)打印 num is not defined

第二種 常態(tài)下的this對(duì)象和new新的對(duì)象下的this

        var age = 27;
        var obj = {
            age:30,
            say: function(){
                console.log(this.age)
            }
        }
        obj.say();//30  (此時(shí)的this.age指向在本obj對(duì)象ao中查找所以值為30)
        var func = obj.say;//(把obj.say這個(gè)方法提出來付給func,
                          //func是全局函數(shù)所以this指向就是全局變量)
                          
        func();//27 ( 執(zhí)行這個(gè)方法后原本obj.say里的方法體付給func,
              // func無法訪問obj里面面的ao。所以他會(huì)向上找全局變量個(gè)var age = 27)
    

        var foo = "123"
        function aa(){
            var foo = "321"
            this.foo = "456"
            console.log(foo)//console里面這個(gè)foo指的是aa(){}這個(gè)自身內(nèi)的foo
                            //this.foo指的是var foo = ‘123’這個(gè)變量。若打印this.foo則輸出‘456’
                            //原因是初始化值被覆蓋掉了
        }
        aa()
            
        var foo = "321"
        function pints(){
            this.foo = "123"
            console.log(foo)//console里面的foo是全局變量var foo = 321 這個(gè),
                            //pints()里面沒有變量foo,因?yàn)闆]有聲明,
                            //this.foo指的是var foo=321 
                            //當(dāng)前值123覆蓋了foo原聲明時(shí)的值321所以打印123
        }
        pints()
        
        var foo = "123"
        function test(){
            this.foo = "654"
            console.log(foo)
        }
        new test()//new一個(gè)test()后,不能讀到之前的test()里面的foo,只能讀取全局的foo

第三種 常態(tài)下的this對(duì)象和new新的對(duì)象下的this

//    箭頭函數(shù)里的前頭函數(shù)指向上級(jí)作用域
        var age = 26;
        var obj = {
            age:32,
            say:()=> {//箭頭函數(shù)指向是上級(jí)作用域
                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 此時(shí)的this.age指向上級(jí)作用域中的var age = 26;
                                     // 執(zhí)行函數(shù)預(yù)編譯后this.age的值覆蓋age的初始值
                function fu(){
                    console.log(age) // 26  此時(shí)打印的是全局變量的初始值,這時(shí)的age在Person中沒有找到age,
                                    //  會(huì)再向上搜索所以找到了age=26
                }
                fu();
            }
            say();
        }
        var x = new Person() //22  new等同于Person()的命令

差不多就這些情況了,希望通過這些例子能夠幫助大家理解this對(duì)象。如果例題中有不對(duì)的地方希望予以指教留言評(píng)論?。。?/p>

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/106794.html

相關(guān)文章

  • JavaScript深入淺出

    摘要:理解的函數(shù)基礎(chǔ)要搞好深入淺出原型使用原型模型,雖然這經(jīng)常被當(dāng)作缺點(diǎn)提及,但是只要善于運(yùn)用,其實(shí)基于原型的繼承模型比傳統(tǒng)的類繼承還要強(qiáng)大。中文指南基本操作指南二繼續(xù)熟悉的幾對(duì)方法,包括,,。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。 怎樣使用 this 因?yàn)楸救藢儆趥吻岸?,因此文中只看懂?8 成左右,希望能夠給大家?guī)韼椭?...(據(jù)說是阿里的前端妹子寫的) this 的值到底...

    blair 評(píng)論0 收藏0
  • 【譯】javascriptthis關(guān)鍵詞理解

    摘要:在中,當(dāng)使用關(guān)鍵字調(diào)用函數(shù)構(gòu)造函數(shù)時(shí),函數(shù)構(gòu)造函數(shù)中也有這個(gè)概念,但是它不是惟一的規(guī)則,而且常??梢砸脕碜圆煌瑘?zhí)行上下文的不同對(duì)象。因此,我們使用調(diào)用函數(shù),可以看到這是對(duì)象,并且的屬性是正常的。 一直以來,javascript里邊的this都是一個(gè)很難理解的東西,之前看的最多的就是阮一峰老師關(guān)于this的理解: http://www.ruanyifeng.com/blo... htt...

    tainzhi 評(píng)論0 收藏0
  • 關(guān)于javascriptthis指向

    摘要:當(dāng)中的是一個(gè)用于指向當(dāng)前上下文對(duì)象的關(guān)鍵字。創(chuàng)建實(shí)例時(shí)的構(gòu)造函數(shù)中的,永遠(yuǎn)指向那個(gè)實(shí)例后對(duì)象,不是外部環(huán)境使用來調(diào)用函數(shù)時(shí),先改變其上下文環(huán)境,在對(duì)其構(gòu)造函數(shù)進(jìn)行調(diào)用。 javascript 當(dāng)中的 this是一個(gè)用于指向當(dāng)前上下文對(duì)象的關(guān)鍵字。在面向?qū)ο缶幊碳叭粘i_發(fā)當(dāng)中我們經(jīng)常與其打交道,初學(xué)javscript的朋友非常容易誤入歧途從而理解錯(cuò)誤。 上下文對(duì)象概念 在我的深入貫徹閉包...

    蘇丹 評(píng)論0 收藏0
  • 關(guān)于javascriptthis指向

    摘要:關(guān)于中的指向我上的菜鳥倉庫地址點(diǎn)擊跳轉(zhuǎn)查看其他相關(guān)文章文章在我的博客上的地址點(diǎn)擊跳轉(zhuǎn)學(xué)習(xí),必不可少的肯定要理解的指向。 關(guān)于javascript中this的指向 我GitHub上的菜鳥倉庫地址: 點(diǎn)擊跳轉(zhuǎn)查看其他相關(guān)文章 文章在我的博客上的地址: 點(diǎn)擊跳轉(zhuǎn) ? ? ? ? 學(xué)習(xí)javascript,必不可少的肯定要理解this的指向。要學(xué)習(xí)this指向之前,就要先理解了我前面寫的幾...

    shinezejian 評(píng)論0 收藏0
  • 理解 JavaScript this

    摘要:回調(diào)函數(shù)在回調(diào)函數(shù)中的指向也會(huì)發(fā)生變化。在閉包回調(diào)函數(shù)賦值等場(chǎng)景下我們都可以利用來改變的指向,以達(dá)到我們的預(yù)期。文章參考系列文章理解閉包理解執(zhí)行棧理解作用域理解數(shù)據(jù)類型與變量原文發(fā)布在我的公眾號(hào),點(diǎn)擊查看。 這是本系列的第 5 篇文章。 還記得上一篇文章中的閉包嗎?點(diǎn)擊查看文章 理解 JavaScript 閉包 。 在聊 this 之前,先來復(fù)習(xí)一下閉包: var name = Nei...

    zombieda 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<