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)
}

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])
}

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())

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);
添加回答
舉報