亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

調用外部函數作為對象的屬性

調用外部函數作為對象的屬性

慕容森 2023-06-15 16:14:23
我有一組對象,此刻里面只有一個對象。在這個對象中,我有一個函數可以詳細說明同一對象的某些屬性。該函數在數組外處理,但結果是 NaN,我不知道如何正確傳遞值。例子let arrayObj = [{  number1: 1,  number2: 2,  sum: sum(this.number1 , this.number2)}]function sum(n1, n2) {  return console.log(n1 + n2);}結果:NaN。for (let i in arrayObj){  console.log(arrayObj[i])}結果:{number1: 1, number2: 2, sum: undefined}
查看完整描述

4 回答

?
函數式編程

TA貢獻1807條經驗 獲得超9個贊

如果在對象創建期間想要一個完全可用的對象,請使用 Function 對象。


let arrayObj = [new function(){

  this.number1 = 1;

  this.number2 = 2;

  this.sum = sum(this.number1 , this.number2)

}]


// minor edit to return the sum instead of returning the result of the console log

function sum(n1, n2) {

  console.log(n1 + n2);

  return n1 + n2;

}


for (let i in arrayObj){

  console.log(arrayObj[i])

}

但是,如果您以后需要此功能,并希望所有這些對象都可以訪問它,那么請停止使用匿名對象并創建一個實際的類或原型。


原型:


function Point(number1, number2){

 this.number1 = number1;

 this.number2 = number2;

}

Point.prototype.sum = function(){

 return this.number1 + this.number2;

}


let arrayObj = [

 new Point(1,2),

 new Point(3,4),

 new Point(15,30)

];


for (let i in arrayObj){

  console.log(arrayObj[i].sum())

}

班級:


class Point {

  constructor(number1, number2){

    this.number1 = number1;

    this.number2 = number2;

  }

  get sum(){

      return this.number1 + this.number2;

  }

}


let arrayObj = [

 new Point(1,2),

 new Point(3,4),

 new Point(15,30)

];


for (let i in arrayObj){

  console.log(arrayObj[i].sum)

}


查看完整回答
反對 回復 2023-06-15
?
吃雞游戲

TA貢獻1829條經驗 獲得超7個贊

您可以在遍歷對象時將該屬性添加到對象。


const arrayObj = [{

    number1: 1,

    number2: 2,

}];


function sum(n1, n2) {

  return n1 + n2;

}


for (let i in arrayObj){

  arrayObj[i].sum = sum(arrayObj[i].number1, arrayObj[i].number2)

  console.log(arrayObj[i])

}


查看完整回答
反對 回復 2023-06-15
?
茅侃侃

TA貢獻1842條經驗 獲得超21個贊

有一個簡單的解決方案。您可以在 sum 屬性中放置一個即時函數,并在該函數下,通過將對象的其他所需值轉換為變量來發送它們。見下文:


function sum(n1, n2) {

    return n1 + n2;

}

const arrayObj = [{

        'number1': 1,

        'number2': 2,

        'sum': function () {

            let num1 = this.number1, num2 = this.number2;

            return sum(num1, num2);

        }

    }];


console.log(arrayObj.sum())


查看完整回答
反對 回復 2023-06-15
?
隔江千里

TA貢獻1906條經驗 獲得超10個贊

對于這個問題,我找到了另一個有趣的解決方案(我不記得是在哪里找到的。)。使用javascript 的getter 函數可以輕松解決問題。您可以直接在對象中使用它來使用外部函數。如果對象的屬性(鍵)使用外部函數來獲取值,并且它的行為必須像普通的“鍵:值”對(不是方法/函數),那么 getter 函數是最好的使用方法得到價值。

function sum(n1, n2) {

? ? return n1 + n2;

}

const arrayObj =?

? ? ? {

? ? ? ? get sum() {return sum(this.number1, this.number2)},

? ? ? ? number1: 1,

? ? ? ? number2: 2,

? ? ? ? number3: 4,

? ? ? ? get totalsum() {return sum(this.sum, this.number3)} //using the sum property (that used external function) in another property.

? ? ? };



console.log(arrayObj);

console.log('the sum of '+arrayObj.number1+' & '+arrayObj.number2+' is: '+arrayObj.sum);?


console.log('the sum of '+arrayObj.sum+' & '+arrayObj.number3+' is: '+arrayObj.totalsum);



查看完整回答
反對 回復 2023-06-15
  • 4 回答
  • 0 關注
  • 213 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號