3 回答

TA貢獻2041條經驗 獲得超4個贊
你可以讓它們發揮作用:
const language_settings = {
en: {
NOTIFICATION: 'Send notification to my phone',
getTimeRemaining: seconds => `Remaining time ${seconds} seconds`
},
fr: {
NOTIFICATION: 'Envoyer verification sur mon portable',
getTimeRemaining: seconds => `Temps restant ${seconds} secondes`
}
}

TA貢獻1824條經驗 獲得超6個贊
您還可以使用Object.definePropertygetter/setter 動態定義對象屬性,然后利用這些函數動態設置秒值。
seconds下面的代碼片段將首先打印值為 1 的值,當seconds更改為 5 時,則記錄的語句將打印為 5。
let seconds = 1;
const language_settings = {
en: {
NOTIFICATION: 'Send notification to my phone',
},
fr: {
NOTIFICATION: 'Envoyer verification sur mon portable',
}
}
Object.defineProperty(language_settings.en, 'TIME_REMANING', {
get : () => { return `Remaining time ${seconds} seconds`}
});
Object.defineProperty(language_settings.fr, 'TIME_REMANING', {
get : () => { return `Temps restant ${seconds} secondes` }
});
console.log(seconds, language_settings.en.TIME_REMANING, language_settings.fr.TIME_REMANING);
console.log('change second to 5');
seconds = 5;
console.log(seconds, language_settings.en.TIME_REMANING, language_settings.fr.TIME_REMANING);

TA貢獻1872條經驗 獲得超4個贊
一種快速而骯臟的方法是像這樣定義字符串:“剩余時間 $0 秒”并在每次使用它時調用 .replace(“$0”, 秒) 。我知道一款名為 CS:GO 的流行游戲就是這樣做的。
或者在 NPM 上找到一個做得更好的模板引擎
但 JS 字符串模板(反引號字符串)不是為此而設計的。您還可以使用接受值并返回生成的字符串的函數
添加回答
舉報