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

javascript 具名函數(shù)的四種調(diào)用方式 推薦第2/3頁

 更新時間:2009年07月05日 01:06:45   作者:  
看四種方式執(zhí)行結(jié)果沒有區(qū)別。但如果函數(shù)有返回值的話,用new方式調(diào)用時可能會讓你有些失望。

以函數(shù)中有無this來討論。沒有this時返回一個空的對象{},有this時返回一個非空對象。
定義一個沒有this的函數(shù)
復(fù)制代碼 代碼如下:

//返回值是基本類型
function fun() {
return "jack";
}

var c = new fun();
for (var atr in c) {
alert(atr);
}
alert(c);//[object Object]

返回值c不是"jack", 從for in執(zhí)行后沒有輸出任何屬性可以看出 c 是一個空的對象{}。

再看看有this的函數(shù),函數(shù)中有this實際上是在寫一個類。但由于js的靈活性,造成了許多詭異的寫法。
復(fù)制代碼 代碼如下:

//返回值是基本類型
function fun() {
this.name = "tom";
return "jack";
}

var c = new fun();
for (var atr in c) {
alert(atr);//name
}
alert(c.name);//tom

返回值也不是"jack",for in輸出了name屬性,最后一句輸出了tom,說明返回值 c 是一個非空對象。這里的return "jack"壓根沒起作用。所以當函數(shù)返回值是內(nèi)置類型(基本類型)時,用new方式調(diào)用函數(shù)將會導(dǎo)致錯誤的結(jié)果 。

那么當函數(shù)返回值是一個對象,數(shù)組,函數(shù)呢?
復(fù)制代碼 代碼如下:

//不含this,返回值是一個對象
function fun() {
//組裝一個對象
var obj = {};
obj.name = 'andy';
obj.age = 20;
obj.msg = function(){}

return obj;
}

var c = new fun();
for (var atr in c) {
alert(atr);//name,age,msg
}
alert(c.name);//andy

復(fù)制代碼 代碼如下:

//含this,返回值是一個對象
function fun() {
this.sex = "man";
//組裝一個對象
var obj = {};
obj.name = 'andy';
obj.age = 20;
obj.msg = function(){}

return obj;
}

var c = new fun();
for (var atr in c) {
alert(atr);//name,age,msg
}
alert(c.name);//andy

兩段的輸出結(jié)果是一樣的,c都含有name,age,msg屬性而不含sex屬性。說明當返回值是對象類型(對象,數(shù)組,函數(shù))時,new不會用this去構(gòu)造對象,而直接返回組裝的對象。

這種方式實際上是工廠方式,在應(yīng)用中更多的程序員把函數(shù)名首字母大寫,讓它看起來更像一個類。

相關(guān)文章

  • JavaScript迭代器的含義及用法

    JavaScript迭代器的含義及用法

    這篇文章主要介紹了JavaScript迭代器的含義及用法,迭代器就是為實現(xiàn)對不同集合進行統(tǒng)一遍歷操作的一種機制,只要給需要遍歷的數(shù)據(jù)結(jié)構(gòu)部署Iterator接口,通過調(diào)用該接口,或者使用消耗該接口的API實現(xiàn)遍歷操作。,需要的朋友可以參考下
    2019-06-06
  • 詳解基于webpack&gettext的前端多語言方案

    詳解基于webpack&gettext的前端多語言方案

    這篇文章主要介紹了詳解基于webpack&gettext的前端多語言方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • Javascript中replace()小結(jié)

    Javascript中replace()小結(jié)

    在javascript中,replace方法是屬于String對象的,可用于替換字符串。今天我們就來詳細探討下一些replace()方法的使用
    2015-09-09
  • javascript表單驗證以及正則表達式舉例詳解

    javascript表單驗證以及正則表達式舉例詳解

    正則表達式描述了一種字符串匹配的模式,可以用來檢查一個串是否含有某種子串、將匹配的子串替換或者從某個串中取出符合某個條件的子串等,常用于表單驗證等,下面這篇文章主要給大家介紹了關(guān)于javascript表單驗證以及正則表達式的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • 圖片上傳判斷及預(yù)覽腳本的效果實例

    圖片上傳判斷及預(yù)覽腳本的效果實例

    這篇文章介紹了圖片上傳判斷及預(yù)覽腳本的效果實例,有需要的朋友可以參考一下
    2013-08-08
  • IE與FireFox中的childNodes區(qū)別

    IE與FireFox中的childNodes區(qū)別

    Javascript中,相信大家都試過用getElementsByTagName和childNodes來實現(xiàn)對節(jié)點的遍歷
    2011-10-10
  • 基于bootstrap實現(xiàn)廣告輪播帶圖片和文字效果

    基于bootstrap實現(xiàn)廣告輪播帶圖片和文字效果

    這篇文章主要介紹了基于bootstrap實現(xiàn)廣告輪播帶圖片和文字效果,效果非常棒,需要的朋友可以參考下
    2016-07-07
  • 用JavaScript做簡易的購物車的代碼示例

    用JavaScript做簡易的購物車的代碼示例

    這篇文章主要介紹了用JavaScript做簡易的購物車的代碼示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • js/jquery解析json和數(shù)組格式的方法詳解

    js/jquery解析json和數(shù)組格式的方法詳解

    本篇文章主要是對js/jquery解析json和數(shù)組格式的方法進行了詳細的介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • 使用SpreadJS快速清除Excel中工作表保護密碼

    使用SpreadJS快速清除Excel中工作表保護密碼

    這篇文章主要為大家介紹了使用SpreadJS快速清除Excel中工作表保護密碼方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11

最新評論