函數(shù)名想象成指針,有助于理解為什么ECMAScript為什么沒有函數(shù)重載的概念
重載:重新全部的加載
廢話不多說直接列子
function add(num){
return num+100
}
function add(num){
return num+200
}
add(100) //300
有人會(huì)說最后一個(gè)函數(shù)覆蓋了第一個(gè) 這樣說似乎也是對(duì)的 。 但是其實(shí)是最后一個(gè)函數(shù)add函數(shù)名字覆蓋的指針覆蓋了第一個(gè) 記住函數(shù)名師指針 指向函數(shù)函數(shù)聲明就相當(dāng)于開辟了一個(gè)內(nèi)存空間JS不允許訪問內(nèi)存的所以只是一個(gè)指針
其實(shí)這個(gè)樣理解
var add=function(num){
return num+100}
var add=function(num){
return num+200}
第二個(gè)add這個(gè)函數(shù)名字覆蓋的第一個(gè)add他們是指針指針指針 并沒有改變函數(shù)
以上純屬自己理解如有錯(cuò)誤請(qǐng)指出
所以說JS沒有函數(shù)重載只會(huì)模擬函數(shù)重載
函數(shù)的內(nèi)部屬性
二個(gè)特殊的屬性:argument 和this
arguments是一個(gè)類數(shù)組為什么是類數(shù)組 他是一個(gè)數(shù)組但是也有函數(shù)里面的一些指針
作用:主要用途是保存函數(shù)的參數(shù) (實(shí)參)
他的屬性:
callee 是一個(gè)指向擁有argument函數(shù)本身的一個(gè)指針(在遞歸 階乘中使用解決函數(shù)名的耦合性)
this:不多介紹 函數(shù)最終被誰調(diào)用一般都指向誰(一般用在構(gòu)造函數(shù)中使用)
屬性和方法
萬物皆對(duì)象 函數(shù)也不例外所以也有自己的屬性和方法
二個(gè)屬性方法
length 形參的長(zhǎng)度
prototype 保存函數(shù)實(shí)例方法的真正所在 (這個(gè)很重要的一個(gè)屬性對(duì)于繼承來說)es5中這個(gè)屬性不能枚舉(枚舉就是for in遍歷)
apply/call 這兩個(gè)都是在特定的作用域調(diào)用函數(shù)(設(shè)置函數(shù)體中this對(duì)象值一般用于繼承)
小東西
自己試驗(yàn) 新建一個(gè)add函數(shù) 控制臺(tái)打印add 然后在打印add.prototype
在打印add.prototype.constructor 然后在add.prototype.constructor.prototype 大概知道了吧 你可以無限點(diǎn)下去 無限循環(huán)下去 這個(gè)就是指針 是不是感覺懂了!?。?br>
另外這個(gè)proto有指向這個(gè)函數(shù)的prototype屬性你可以如上面的方法打印一下一個(gè)無限的指向