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

javascript的函數(shù)

 更新時間:2006年07月28日 00:00:00   作者:  

將函數(shù)作為屬性

任何類型的對象都可以作為一個屬性,回憶一下前面的Example 4(不是Example DT4),函數(shù)也是一個對象。所以你可以讓一個函數(shù)作為一個對象的一個屬性。下面,我將添加兩個函數(shù)getSalary和addSalary。

Example DT7

CODE:

function Employee(name, salary)
{
  this.name=name;               
  this.salary=salary;

  this.addSalary=addSalaryFunction;

  this.getSalary=function()
                 {
                   return this.salary;
                 };
}
function addSalaryFunction(addition)
{
  this.salary=this.salary+addition;
}

var boss=new Employee("John", 200000);
boss.addSalary(10000);                    // boss 長了 10K 工資……為什么老板工資可以長這么多:'(
alert(boss.getSalary());                  // 輸出 210K……為什么默認(rèn)工資也那么高……:'(

addSalary和getSalary演示了幾種將函數(shù)賦給屬性的不同方法。如果你記得我們最開始的討論;我討論了三種聲明函數(shù)的不同方式。所有那些在這里都是適用的,但是上面展示的兩個最常用。

讓我們看看有什么不同。下面,注意一下9-12行的代碼。當(dāng)這部分代碼執(zhí)行的時候,函數(shù)getSalary被聲明。如前面數(shù)次提到的,一個函數(shù)聲明的結(jié)果是一個對象被創(chuàng)建。所以這時候boss被創(chuàng)建(接下來的第19行),而boss里有一個getSalary屬性。

CODE:

function Employee(name, salary)
{
  this.name=name;               
  this.salary=salary;

  this.addSalary=addSalaryFunction;

  this.getSalary=function()
                 {
                   return this.salary;
                 };
}
function addSalaryFunction(addition)
{
  this.salary=this.salary+addition;
}

var boss=new Employee("John", 200000);
var boss2=new Employee("Joan", 200000);
var boss3=new Employee("Kim", 200000);

當(dāng)你創(chuàng)建這個對象的更多實例時(boss2和boss3),每一個實例都有一份getSalary代碼的單獨拷貝;而與此相反,addSalary則指向了同一個地方(即addSalaryFunction)。 

看看下面的代碼來理解一下上面所描述的內(nèi)容。

Example DT8

CODE:

function Employee(name, salary)
{
  this.name=name;               
  this.salary=salary;

  this.addSalary=addSalaryFunction;
  this.getSalary=function()
                 {
                   return this.salary;
                 };
}
function addSalaryFunction(addition)
{
  this.salary=this.salary+addition;
}

var boss1=new Employee("John", 200000);
var boss2=new Employee("Joan", 200000);


// 給getSalary函數(shù)對象添加屬性
boss1.getSalary.owner="boss1";
boss2.getSalary.owner="boss2";
alert(boss1.getSalary.owner);   // 輸出 "boss1"
alert(boss2.getSalary.owner);   // 輸出 "boss2"
// 如果兩個對象指向同一個函數(shù)對象,那么
// 上面兩個輸出都應(yīng)該是“boss2”。

// 給addSalary函數(shù)對象添加屬性
boss1.addSalary.owner="boss1";
boss1.addSalary.owner="boss2";
alert(boss1.addSalary.owner);   // 輸出 "boss2"
alert(boss2.addSalary.owner);   // 輸出 "boss2"
// 因為兩個對象都指向同一個函數(shù),(子烏注:原文寫are not pointing to the same function,疑為筆誤)
// 當(dāng)修改其中一個的時候,會影響所有的實例(所以兩個都輸出“boss2”).

也許不是重要的事情,但這里有一些關(guān)于運行類似上面的getSalary的內(nèi)嵌函數(shù)的結(jié)論: 1) 需要更多的存儲空間來存儲對象(因為每一個對象實例都會有它自己的getSalary代碼拷貝);2) javascript需要更多時間來構(gòu)造這個對象。

讓我們重新寫這個示例來讓它更有效率些。

Example DT9

CODE:

function Employee(name, salary)
{
  this.name=name;               
  this.salary=salary;

  this.addSalary=addSalaryFunction;
  this.getSalary=getSalaryFunction;
}
function getSalaryFunction()
{
  return this.salary;
}

function addSalaryFunction(addition)
{
  this.salary=this.salary+addition;
}

 

看這兒,兩個函數(shù)都指向同一個地方,這將會節(jié)約空間和縮短構(gòu)造時間(特別是當(dāng)你有一大堆內(nèi)嵌函數(shù)在一個構(gòu)造函數(shù)的時候)。這里有另外一個函數(shù)的功能能夠來提升這個設(shè)計,它叫做prototype,而我們將在下一節(jié)討論它。

相關(guān)文章

  • Javascript條件判斷使用小技巧總結(jié)

    Javascript條件判斷使用小技巧總結(jié)

    我們已經(jīng)知道,null?沒有任何的屬性值,并且無法獲取其實體(existence)值。所以?null.property?返回的是錯誤(error)而不是?undefined?。
    2008-09-09
  • JS實現(xiàn)滑動條案例

    JS實現(xiàn)滑動條案例

    這篇文章主要為大家詳細(xì)介紹了JS實現(xiàn)滑動條案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • javascript中的糖衣語法Promise對象詳解

    javascript中的糖衣語法Promise對象詳解

    這篇文章主要介紹了javascript中的糖衣語法Promise對象詳解,Promise 對象代表了未來將要發(fā)生的事件,用來傳遞異步操作的消息,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • 基于JS實現(xiàn)回到頁面頂部的五種寫法(從實現(xiàn)到增強)

    基于JS實現(xiàn)回到頁面頂部的五種寫法(從實現(xiàn)到增強)

    這篇文章主要介紹了基于JS實現(xiàn)回到頁面頂部的五種寫法(從實現(xiàn)到增強)的相關(guān)資料,本文介紹的非常詳細(xì),實用性也非常高,非常具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • javascript 跨瀏覽器開發(fā)經(jīng)驗總結(jié)(五) js 事件

    javascript 跨瀏覽器開發(fā)經(jīng)驗總結(jié)(五) js 事件

    javascript 跨瀏覽器開發(fā)之js 事件的兼容性問題,需要的朋友可以參考下。
    2010-05-05
  • JavaScript異步隊列進行try?catch時的問題解決

    JavaScript異步隊列進行try?catch時的問題解決

    這篇文章主要介紹了JavaScript異步隊列進行try?catch時的問題解決,文章圍繞主題展開詳細(xì)的的相關(guān)內(nèi)容介紹,需要的朋友可以參考一下
    2022-07-07
  • JS中6個對象數(shù)組去重的方法

    JS中6個對象數(shù)組去重的方法

    這篇文章主要給大家介紹了關(guān)于JS中6個對象數(shù)組去重的方法,javascript數(shù)組去重是一個比較常見的需求,解決方法也有很多種,文中每種解決方法都給出了示例代碼,需要的朋友可以參考下
    2023-07-07
  • uniapp開發(fā)APP之強制更新和熱更新的實現(xiàn)

    uniapp開發(fā)APP之強制更新和熱更新的實現(xiàn)

    使用uni-app開發(fā),可將代碼編譯到iOS、Android、微信小程序等多個平臺,升級時也需考慮多平臺同步升級,下面這篇文章主要給大家介紹了關(guān)于uniapp開發(fā)APP之強制更新和熱更新的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • 使用Fullpage插件快速開發(fā)整屏翻頁的頁面

    使用Fullpage插件快速開發(fā)整屏翻頁的頁面

    這篇文章給大家分析使用Fullpage插件快速開發(fā)整屏翻頁的頁面,適用于各大網(wǎng)站,此功能非常高大上,下面就跟隨腳本之家小編看看Fullpage插件是怎么實現(xiàn)此效果的
    2017-09-09
  • javascript中的float運算精度實例分析

    javascript中的float運算精度實例分析

    javascript中的float運算精度的一些問題,下面是具體的說明。
    2010-08-08

最新評論