JavaScript (Vue) コードでオブジェクトのプロパティが読み取り専用としてマークされているのはなぜですか?
<p><code>boxes</code> という状態変数 (ボックス オブジェクトを含む配列) を持つ Vue 2 アプリケーションがあります。これらのボックスのサブセットを抽出する計算されたプロパティがあります (<code>nearest_box_linked_boxes</code>)。 </p>
<p><code>nearest_box_linked_boxes</code> によって返されたボックスをループし、各要素の属性の値を変更するメソッドがあります。
<pre class="brush:php;toolbar:false;">for(let i=0;i<this.nearest_box_linked_boxes.length;i )
{
let box = this.nearest_box_linked_boxes[i];
box.object_class = this.$store.state.selected_object_class;
ボックス.パッチ();
}</pre>
<p>このメソッドはエラーを返しました: </p>
<pre class="brush:php;toolbar:false;">vue.esm.js:648 [Vue warn]: v-on ハンドラーのエラー: "TypeError: の読み取り専用プロパティ 'object_class' に割り当てることができませんオブジェクト '#<Box>'''</pre>
<p>ボックス オブジェクト (またはそのプロパティ) を明示的に読み取り専用にしたことはありません。 <code>nearest_box_linked_boxes</code> (親配列オブジェクト) は計算されたプロパティであるため、書き込むことができないことはわかっていますが、この配列内の各要素のプロパティを変更することはできるはずだと思います。 </p>
<p>Vue と計算プロパティが原因で問題が発生しているのでしょうか、それとも別の原因でしょうか? </p>