久久久久在线观看_又色又爽又黄的免费视频播放_一区中文字幕_日韩电影在线播放

今日焦點 焦點資訊 營銷之道 企業報道 淘寶運營 網站建設 軟件開發 400電話
  當前位置: 首頁 » 資訊 » 軟件開發 » 正文

js函數需要掌握的知識

放大字體  縮小字體 發布日期:2018-02-28  來源:企業800網  作者:新格網  瀏覽次數:118  【去百度看看】
核心提示:?要知道,在js中,引用類型是一種數據結構,包含5種引用類型,分別是Object,data,Array,re請輸入代碼gExp,Function。今天我們就說Function這種數據結構。 在js種函數實際上是對象,每個函數都是Function類型的實例。和其他引用類型一樣,都具有屬性和方法。
要知道,在js中,引用類型是一種數據結構,包含5種引用類型,分別是Object,data,Array,re請輸入代碼gExp,Function。今天我們就說Function這種數據結構。 在js種函數實際上是對象,每個函數都是Function類型的實例。和其他引用類型一樣,都具有屬性和方法。

1. 函數定義有幾種方法

  1. 函數聲明語法定義

        function sum(num1,num2){
       return num1+num2;
      }
  2. 函數表達式
    注意函數表達式后邊有一個分號;

   var sum=function(num1,num2){
      return num1+num2;
}
  1. 使用Function 構造函數

    使用構造函數可以接收任意數量的參數,但最后一個參數始終被看成是函數體,而前面的參數則枚舉出了參數
var sum=new Function("num1","num2","return num1+num2")

當然第三種方法不友好,也不推薦。

函數名僅僅是指向函數的指針,所以函數名與包含對象指針的其他變量沒有什么不同。也就是說一個函數可能會有多個名字。

在這里函數聲明和函數表達式有什么區別呢?
解析器在向執行環境中加載數據的時候,對函數聲明和函數表達式是不一樣的。解析器首先會讀取函數聲明,并且使得這段函數聲明代碼在任何代碼之前都可調用。這就是我們平時所說的函數聲明提升。函數表達式不一樣,他必須等到函數解析器執行到他所在的代碼塊的時候,才會被真正的執行。比較下面2個例子

console.log(sum(10,10));

function sum(n1,n2){
   return n1+n2;
}

以上代碼會正常執行

再看!

console.log(sum(10,10));

var sum=function(n1,n2){
   return n1+n2;
}

以上執行器就會報錯!

2.函數沒有重載

如果聲明了2個同名函數,結果是后面的函數覆蓋了前面的函數。

function sun(a){
  return a+100;
}
function sun(a){
  return a+200;
}

var result=sum(2)//202

3.函數的內部屬性

  • 包括this,arguments

    具體不再敘述了

4.函數的屬性和方法

  • 函數有2個屬性,length和prototype

length表示函數希望接收命名參數的個數。

function a(name){
 //todo
}
function b(name,age){
 //todo
}
function c(){
 //todo
}

a.length //1
b.length //2
c.length //0

prototype屬性對于引用類型來說很重要,會有專門講解,此處不再這贅述。

  • 每個函數都包含2個非繼承的方法 apply,call

這兩個方法的用途都是在特定的作用域中調用函數,其實就是設置函數體內的this指代的值。

首先。apply()方法接收2個參數,一個是函數運行的作用域,另一個是參數數組,第二個參數可以是數組的實例,也可以是arguments.

function sum(num1,num2){
   return num1+num2;
}

function test1(a,b){
    return sum.apply(this,arguments);
}

function test2(c,d){
    return sum.apply(this.[c,d]);
}

console.log(test1(1,1)) //2

console.log(test2(1,1)) //2

call方法和apply方法沒有多大的區別。區別就是call方法的第二個參數必須得傳遞的參數一個個列舉出來。

使用call和apply來擴充作用域最大的好處就是對象不和任何方法耦合。

相關推薦:

JS函數實例詳解

js函數的按值傳遞參數

js函數的調用及有關隱式參數arguments和this的問題

以上就是js函數需要掌握的知識的詳細內容,更多請關注php中文網其它相關文章!

 
 
[ 資訊搜索 ]  [ 加入收藏 ]  [ 告訴好友 ]  [ 打印本文 ]  [ 違規舉報 ]  [ 關閉窗口 ]

 
0條 [查看全部]  相關評論

 
網站首頁 | 關于我們 | 聯系方式 | 使用協議 | 版權隱私 | 網站地圖 | 排名推廣 | 廣告服務 | 積分換禮 | 網站留言 | RSS訂閱 | 皖ICP備2021004516號-14
企業800網 · 提供技術支持