亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JS中this的指向以及call、apply的作用

2024-05-06 16:44:07
字體:
來源:轉載
供稿:網友

在具體的實際應用中,this 的指向無法在函數定義時確定,而是在函數執行的時候才確定的,根據執行時的環境大致可以分為以下3種:

1、當函數作為普通函數調用時,this 指向全局對象

2、當函數作為對象的方法調用時,this 指向該對象

3、當函數作為構造器調用時,this 指向新創建的對象

示例一:

window.name = 'myname';function getName() {  console.log(this.name);}getName(); //輸出myname

示例二:

var boy = {  name: 'Bob',  getName: function() {    console.log(this.name);  }}boy.getName(); //輸出Bob

示例三:

function Boy(name) {  this.name = name;}var boy1 = new Boy('Bob');console.log(boy1.name); //輸出Bob

對于示例三,還有一種特殊情況,就是當構造函數通過 "return" 返回的是一個對象的時候,此次運算的最終結果返回的就是這個對象,而不是新創建的對象,因此 this 在這種情況下并沒有什么用。

示例四:

function Boy(name) {  this.name = name;  return { //返回一個對象    name: 'Jack'  }}var boy1 = new Boy('Bob');console.log(boy1.name); //輸出Jack

示例五:

function Boy(name) {  this.name = name;  return 1; //返回非對象}var boy1 = new Boy('Bob');console.log(boy1.name); //輸出Bob

call 和 apply 的作用

apply 接受兩個參數,第一個參數指定了函數體內 this 的指向,第二個參數是一個數組或類數組,用于傳遞被調用函數的參數列表。

示例一:

function getInfo() {  console.log(this.name+' like '+arguments[0]+' and '+arguments[1]);}var boy1 = {  name: 'Bob',  age: 12}getInfo.apply(boy1,['sing','swimming']); //輸出Bob like sing and swimming

call 傳入參數的數量是不固定的,跟 apply 相同的是,第一個參數也是用于指定函數體內 this 的指向,從第二個參數開始往后,每個參數被依次傳入被調用函數。

示例二:

function getInfo() {  console.log(this.name+' like '+arguments[0]+' and '+arguments[1]);}var boy1 = {  name: 'Bob',  age: 12}getInfo.call(boy1,'sing','shopping'); //輸出Bob like sing and shopping

此外,大部分高級瀏覽器還實現了 bind 方法,它與 call 和 apply 的區別在于 bind 只是改變函數內部 this 的指向,但不會立即執行,你需要顯示調用它。

示例三:模擬瀏覽器的 bind 方法

Function.prototype.bind = function(obj){  var self = this;  return function(){    return self.apply(obj,arguments);  }};var obj = {  name: 'Bob',  age: 12};var func = function(){  console.log(this.name+' like '+arguments[0]+' and '+arguments[1]);}.bind(obj);func('sing','shopping');

丟失的 this

在某些情況下會丟失 this 的指向,此時,我們就需要借助 call、apply 和 bind 來改變 this 的指向問題。

示例一:當 "getName" 方法作為 "boy" 對象的屬性調用時,this 指向 "boy" 對象,當另外一個變量引用 "getName" 方法時,因為它是作為普通函數調用,所以 this 指向全局對象window

var boy = {  name: 'Bob',  getName: function() {    console.log(this.name);  }}boy.getName(); //輸出Bobvar getBoyName = boy.getName;getBoyName(); //輸出undefined

示例二:即使在函數內部定義的函數,如果它作為普通對象調用,this 同樣指向 window 對象

var boy1 = {  name: 'Bob',  age: 12,  getInfo: function() {    console.log(this.name);    function getAge() {      console.log(this.age);    }    getAge();  }}boy1.getInfo(); //Bob        //undefined

 


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
美女撒尿一区二区三区| 欧美日韩视频免费播放| 91国产美女在线观看| 91免费综合在线| 欧美日韩一二三四五区| 亚洲第一综合天堂另类专| 国产精品视频一区二区高潮| 国产精品视频一区二区三区四| 亚洲人a成www在线影院| 欧美亚洲国产视频| 久久久影视精品| 日韩动漫免费观看电视剧高清| 国产91成人在在线播放| 日韩极品精品视频免费观看| www.日韩视频| 欧美大胆在线视频| 日本精品视频在线观看| 日韩av大片免费看| 色综合久久88| 成人免费看黄网站| 国产一区av在线| 欧美性xxxxx极品娇小| 亚洲久久久久久久久久久| 在线精品视频视频中文字幕| 欧美成人三级视频网站| 日韩亚洲综合在线| 日韩亚洲欧美成人| 国产v综合ⅴ日韩v欧美大片| 久久精品91久久久久久再现| 国产精品久久久久久久av电影| 欧美人与性动交| 国产一区二区av| 国产精品99免视看9| 国产日韩欧美夫妻视频在线观看| 亚洲欧美在线磁力| 色综合色综合网色综合| 久久免费视频网| 日韩精品小视频| 亚洲自拍偷拍色图| 欧美亚洲国产视频| 78色国产精品| 日韩av电影在线免费播放| 热99在线视频| 97视频免费看| 久久99久久久久久久噜噜| 亚洲第一视频网站| 日本电影亚洲天堂| 激情懂色av一区av二区av| 精品国产乱码久久久久酒店| 久久精品91久久香蕉加勒比| 国模精品视频一区二区| 亚洲第一页中文字幕| 黄色成人av在线| 国产亚洲欧美aaaa| 中文字幕亚洲情99在线| 欧美日韩精品在线视频| 日韩精品免费在线视频| 中文字幕少妇一区二区三区| 91av在线不卡| 亚洲日韩第一页| 日韩精品欧美激情| 亚洲欧美日韩中文在线| 欧美色视频日本高清在线观看| 欧美成人精品在线视频| 亚洲国产成人91精品| 精品久久香蕉国产线看观看gif| 青青久久av北条麻妃黑人| 久久精品一本久久99精品| 国产丝袜一区二区| 亚洲一区二区三区毛片| 日韩国产一区三区| 国产精品黄页免费高清在线观看| 亚洲变态欧美另类捆绑| www日韩中文字幕在线看| 最近中文字幕2019免费| 成人性生交xxxxx网站| 亲子乱一区二区三区电影| 欧美视频一二三| 欧美精品精品精品精品免费| 45www国产精品网站| 在线观看日韩www视频免费| 午夜精品视频在线| 久久视频在线直播| 日韩av在线资源| 欧美精品在线视频观看| 国产一区二区黄| 日韩精品免费看| 中文字幕亚洲欧美日韩2019| 欧美在线精品免播放器视频| 国产精品女人网站| 欧美在线激情视频| 欧美第一黄网免费网站| 亚洲国产日韩一区| 欧美激情一区二区三区久久久| 国产成人一区二区| 国产精品va在线播放我和闺蜜| 国产精品影片在线观看| 精品视频在线播放免| 成人精品久久久| 国产成人在线精品| 中文字幕日韩欧美在线视频| 91精品国产亚洲| 国产精品18久久久久久麻辣| 国产深夜精品福利| 国产精品入口福利| 午夜精品一区二区三区av| 日日狠狠久久偷偷四色综合免费| 亚洲欧美日韩精品久久亚洲区| 国产精品中文字幕久久久| 一本一道久久a久久精品逆3p| 精品夜色国产国偷在线| 欧美体内谢she精2性欧美| 欧美一区视频在线| 久久精品视频在线观看| 亚洲人线精品午夜| 国产成人精品一区二区| 韩国日本不卡在线| 成人一区二区电影| 亚洲国产私拍精品国模在线观看| 日韩精品免费在线播放| 亚洲女同精品视频| 国产精品福利在线| 久久九九国产精品怡红院| 久久久亚洲精选| 精品国产鲁一鲁一区二区张丽| 亚洲精品日韩在线| 久久精品成人欧美大片古装| 欧美精品一二区| 国产日韩精品电影| 成人激情视频在线观看| 国产日韩中文字幕| 91精品国产成人www| 在线免费观看羞羞视频一区二区| 成人www视频在线观看| 亚洲国产精彩中文乱码av在线播放| 777国产偷窥盗摄精品视频| 日韩在线视频免费观看高清中文| 国产精品黄色影片导航在线观看| 国产成人精品电影久久久| 欧美日韩国产页| 狠狠综合久久av一区二区小说| 成人免费福利视频| 国产精品欧美亚洲777777| 狠狠色狠狠色综合日日小说| 亚洲欧美日韩直播| 性金发美女69hd大尺寸| 色吧影院999| 国产精品丝袜久久久久久高清| 成人写真视频福利网| 日韩在线播放视频| 成人在线播放av| 欧美床上激情在线观看| 精品呦交小u女在线| 久久久久国产精品一区| 久久亚洲国产精品成人av秋霞| 亚洲bt天天射| 久久亚洲精品毛片| 久久精品精品电影网| 68精品国产免费久久久久久婷婷| 一本大道香蕉久在线播放29| 中文字幕亚洲综合久久筱田步美| 色噜噜狠狠狠综合曰曰曰| 激情av一区二区| 国产欧美久久一区二区|