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

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

使用方法和設置器有什么區別?

使用方法和設置器有什么區別?

幕布斯6054654 2023-10-14 19:27:58
例如:var person = {  firstName: "John",  lastName : "Doe",  language : "",  set lang(lang) {  this.language = lang.toUpperCase();}};person.lang = "en";console.log(person.language)var person1 = { firstName: "John", lastName : "Doe", language : function(a){return a.toUpperCase()}};console.log(person1.language('en'))這看起來完全一樣,并且方法模式編寫得較少,所以我為什么要使用 setter?
查看完整描述

1 回答

?
qq_花開花謝_0

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

除了 getter 方法之外,我們還可以創建 setter 方法來重新分配對象內現有屬性的值。setter 方法的示例:


const person = {

  _age: 37,

  set age(newAge){

    if (typeof newAge === 'number'){

      this._age = newAge;

    } else {

      console.log('You must assign a number to age');

    }

  }

};


請注意,在上面的示例中:


我們可以檢查分配給 this._age 的值。

當我們使用setter方法時,只有數字值才會重新分配this._age

根據用于重新分配 this._age 的值,會有不同的輸出。

然后使用setter方法:


    person.age = 40;

    console.log(person._age); // Logs: 40

    person.age = '40';        // Logs: You must assign a number to age


像 Age 這樣的 Setter 方法不需要使用一組括號來調用。從語法上看,我們似乎正在重新分配屬性的值。


與 getter 方法一樣,使用 setter 方法也有類似的優點,包括檢查輸入、對屬性執行操作以及顯示對象應如何使用的明確意圖。盡管如此,即使使用 setter 方法,仍然可以直接重新分配屬性。例如,在上面的例子中,我們仍然可以直接設置._age:


person._age = 'forty-five'

console.log(person._age); // Prints forty-five


查看完整回答
反對 回復 2023-10-14
  • 1 回答
  • 0 關注
  • 123 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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