亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

深入理解js函數(shù)的作用域與this指向

 更新時間:2016年05月28日 16:37:18   投稿:jingxian  
下面小編就為大家?guī)硪黄钊肜斫鈐s函數(shù)的作用域與this指向。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

函數(shù)的作用域與this指向是js中很重要的一部分,理清這點東西需要個邏輯,看看我的邏輯怎么樣...

下面是個提綱,可以直接挑你感興趣的條目閱讀。

• 函數(shù)的定義方式:直接定義(window下,內部定義),對象的方法,對象原型的方法;

• 函數(shù)的調用方式:直接調用,call/apply,with

• 對于直接定義的函數(shù)和對象的方法,作用域默認狀態(tài)下是它的定義處的作用域鏈。

• 對于直接定義的函數(shù),this指向window。

• 對于對象的方法,this指向實例化對象(對應于實例化對象默認返回this的情況)。

• 用call/apply改變方法的this指向

• 在函數(shù)或方法的定義時可以通過with改變其作用域鏈。

下面分開來具體說說:

函數(shù)的定義,如提綱中提到的可以分為兩種:直接定義(window下,內部定義),對象的方法(或對象原型的方法)。從下面的示例代碼中可以看到函數(shù)fn1與fn2以及對象的方法doFunction在函數(shù)使用name時name的值來自相應的域。

 

var name = 'window下的name<br/>';
var resultCon;
function fn1() {
  resultCon.innerHTML += name;
}

function MyObj() {
  var name = 'MyObj下的name<br/>';
  this.doFunction = function() {
    resultCon.innerHTML += name;

在使用name的值時將“name”用“this.name”來代替會出現(xiàn)什么情況呢,看下例:

var name = 'window下的name<br/>';
var resultCon;
function fn1() {
  resultCon.innerHTML += this.name;
}

function MyObj() {
  var name = 'MyObj下的name<br/>';
  this.doFunction = function() {
    resultCon.innerHTML += this.name;

從結果來看可以驗證提綱中的第4和5條,也可以看到this和作用域是兩套分離的鏈,遵循個自的變量查詢邏輯,具體的查詢邏輯在下面的性能分析中會提到,如果是新手建議先看一下“js的作用域鏈”方面的基礎知識。

 關于函數(shù)的調用方法,我用下面的方示例說明提綱中的第2、6條:

var name = 'window下的name<br/>';
var resultCon;
function fn1() {
  resultCon.innerHTML += this.name;
}

function MyObj() {
  var name = 'MyObj下的name<br/>';
  this.doFunction = function() {
    resultCon.innerHTML += this.name;

調用時call和apply的使用是為了改變被調用函數(shù)的this指向。with的使用是為了改變被調用函數(shù)中變量的查詢域。我們把上例中的call和name前的this去掉再加上with來演示with的作用。

var name = 'window下的name<br/>';
var resultCon;
function fn1(myScope) {
  with (myScope) {
    resultCon.innerHTML += name;
  }
}

function MyObj(myScope) {
  var name = 'MyObj下的name<br/>';

看到with的使用并不方便,需要在被調用函數(shù)中添加with,有人可能想能不能向下面那樣調用來整體改變變量作用域而不去改變被調用函數(shù)呢?

with (myScope) {
  fn1();
  fn2();
  var obj = new MyObj();
  obj.doFunction();
}

很遺憾,不可以!所以在一些成熟的框架中隨處可見call和apply的使用,卻很少用到with,在用JSHint檢測js語法的時候with處都標了小紅點,在一些js編碼指導中也建議盡量少用with,因為with改變了變量的默認查詢鏈,所以會給后期的維護人員一些困惑,還有性能方面的一些考慮,請慎用with。

以上這篇深入理解js函數(shù)的作用域與this指向就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 微信小程序實現(xiàn)天氣預報功能(附源碼)

    微信小程序實現(xiàn)天氣預報功能(附源碼)

    這篇文章主要介紹了微信小程序實現(xiàn)天氣預報功能(附源碼),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • javascript遞歸函數(shù)定義和用法示例分析

    javascript遞歸函數(shù)定義和用法示例分析

    這篇文章主要介紹了javascript遞歸函數(shù)定義和用法示例分析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • javascript格式化json顯示實例分析

    javascript格式化json顯示實例分析

    這篇文章主要介紹了javascript格式化json顯示,實例分析了javascript操作json格式化的相關技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • BootStrap框架個人總結(bootstrap框架、導航條、下拉菜單、輪播廣告carousel、柵格系統(tǒng)布局、標簽頁tabs、模態(tài)框、菜單定位)

    BootStrap框架個人總結(bootstrap框架、導航條、下拉菜單、輪播廣告carousel、柵格系統(tǒng)布局、標簽頁

    這篇文章主要介紹了BootStrap框架個人總結(bootstrap框架、導航條、下拉菜單、輪播廣告carousel、柵格系統(tǒng)布局、標簽頁tabs、模態(tài)框、菜單定位)的相關資料,需要的朋友可以參考下
    2016-12-12
  • 淺談js中對象的使用

    淺談js中對象的使用

    下面小編就為大家?guī)硪黄獪\談js中對象的使用。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • 微信小程序實現(xiàn)自定義彈窗組件的示例代碼

    微信小程序實現(xiàn)自定義彈窗組件的示例代碼

    這篇文章主要介紹了微信小程序中實現(xiàn)自定義一個帶確定取消的彈窗組件的方法,文中的示例代碼講解詳細,對我們學習小程序開發(fā)有一定幫助,需要的可以參考一下
    2022-06-06
  • OpenCV.js實現(xiàn)喬丹動圖素描效果圖文教程

    OpenCV.js實現(xiàn)喬丹動圖素描效果圖文教程

    這篇文章主要為大家介紹了OpenCV.js實現(xiàn)喬丹動圖素描效果的圖文教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 微信小程序實現(xiàn)上傳圖片

    微信小程序實現(xiàn)上傳圖片

    這篇文章主要介紹了微信小程序實現(xiàn)上傳圖片,預覽、刪除、限制圖片大小、張數(shù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • 詳解JavaScript的原型與原型鏈

    詳解JavaScript的原型與原型鏈

    這篇文章主要為大家詳細介紹了JavaScript原型與原型鏈,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • ES6中箭頭函數(shù)的定義與調用方式詳解

    ES6中箭頭函數(shù)的定義與調用方式詳解

    這篇文章主要給大家介紹了關于ES6中箭頭函數(shù)的定義與調用方式的相關資料,文中通過示例代碼介紹的非常詳細,相信會對大家的學習或者工作帶來一定的幫助,需要的朋友們下面來一起看看吧。
    2017-06-06

最新評論