|
復制代碼 代碼如下:
//無參函數fun1
function fun1() {
alert('我被調用了');
}
fun1()
//有參函數fun2
function fun2(param) {
alert(param);
}
fun2('我被調用了')
ECMAScript3后加入給Function加入了call和apply后,就有了下面兩種
2、call
復制代碼 代碼如下:
//無參函數fun1
function fun1() {
alert('我被調用了');
}
fun1.call(null);
//有參函數fun2
function fun2(param) {
alert(param);
}
fun2.call(null,'我被調用了')
3、apply
復制代碼 代碼如下:
//無參函數fun1
function fun1() {
alert('我被調用了');
}
fun1.apply(null);
//有參函數fun2
function fun2(param) {
alert(param);
}
fun2.apply(null,['我被調用了'])
4、new (不推薦使用這種方式哦 )
復制代碼 代碼如下:
//無參函數fun1
function fun1() {
alert('我被調用了');
}
new fun1();
//有參函數fun2
function fun2(param) {
alert(param);
}
new fun2('我被調用了')
ok,從以上調用方式上看四種方式執行結果沒有區別。但如果函數有返回值的話,用new方式調用時可能會讓你有些失望。
復制代碼 代碼如下:
//有返回值的函數fun
function fun() {
alert('我被調用了');
return "jack";
}
var c = new fun();
alert(c);//[object Object],為什么不是"jack"?
改成這樣,
復制代碼 代碼如下:
//有返回值的函數fun
function fun() {
alert('我被調用了');
return {name:'jack'};
}
var c = new fun();
alert(c.name);//jack,又正常返回了
好了,總結下:用new方式調用函數時。如果存在返回值,當返回值是Javascript的內置類型(基本類型)如字符串(String),數字(Number),布爾(Boolean)等時,將不會返回該值;當返回值是對象,函數,數組等對象類型時,將返回該對象,函數,數組。
當返回值是內置類型(基本類型)時,new fun()到底返回什么呢?下一篇將討論new方式調用的細節。
JavaScript技術:javascript 具名函數的四種調用方式 推薦第1/3頁,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。