どちらもおんなじ機能じゃない?と思いましたが当然別物です。constは変数の変更禁止(プロパティは変更できる)、readonlyはプロパティの変更禁止(変数は変更できる)の違いです。
// const vs readonly
const cons_a = {b: 2} // variable can not be changed but property can be changed
cons_a.b = 1 // property is changeable
let const_b: {readonly b: number} = {b: 2} // property can not be changed but variable can be changed
const_b = {b: 1} // variable is changeable
したがってどちらも変更できないようにするには、constとreadonlyの組み合わせ使用になります。せっかくTypeScriptが型を厳密の管理、変更不可もその一部ですから、利用しない手はないでしょうから変更できない変数やプロパティは明確にしてしてコンパイラのチェック機能を使うべきです。
admin