欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript 普通函數(shù)和構造函數(shù)的區(qū)別

 更新時間:2016年11月05日 09:07:57   投稿:lqh  
這篇文章主要介紹了Javascript 普通函數(shù)和構造函數(shù)的區(qū)別的相關資料,需要的朋友可以參考下

普通函數(shù)和構造函數(shù)的區(qū)別

在命名規(guī)則上,構造函數(shù)一般是首字母大寫,普通函數(shù)遵照小駝峰式命名法。

在函數(shù)調用的時候:

function fn() { }

     構造函數(shù):1. new fn( )
                     2 .構造函數(shù)內部會創(chuàng)建一個新的對象,即f的實例
                     3. 函數(shù)內部的this指向 新創(chuàng)建的f的實例
                     4. 默認的返回值是f的實例

     普通函數(shù):1. fn( )
                     2. 在調用函數(shù)的內部不會創(chuàng)建新的對象
                     3. 函數(shù)內部的this指向調用函數(shù)的對象(如果沒有對象調用,默認是window)
                     4. 返回值由return語句決定 

 構造函數(shù)的返回值:

     有一個默認的返回值,新創(chuàng)建的對象(實例);
     當手動添加返回值后(return語句):

          1. 返回值是基本數(shù)據(jù)類型-->真正的返回值還是那個新創(chuàng)建的對象(實例)
          2. 返回值是復雜數(shù)據(jù)類型(對象)-->真正的返回值是這個對象 

看一個常見的面試題

<script>
  function foo() {
    var f2 = new foo2();
    console.log(f2);  //{a: 3}
    console.log(this); //window
    return true;
  }
  function foo2() {
    console.log(this); //foo2類型的對象 不是foo2函數(shù)
//    this.age = 30;
    return {a: 3};
  }
  var f1 = foo();
  console.log(f1); // true
</script>

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

最新評論