Влияет ли определение переменных внутри вычисляемого свойства на производительность компонентов Vue?
Справочная информация : я создал компонент таблицы, который генерирует таблицу HTML на основе переданных данных.и имеет разные фильтры для каждого столбца, фильтр для всей таблицы, ключи сортировки и т. д., поэтому я определяю множество локальных переменных внутри вычисляемого свойства.
Представьте, что у вас есть массив объектов:
let data = [
{ a: 1, b: 2, c: 3 },
{ a: 11, b: 22, c: 33 }
]
.. который используется компонентом Vue для отображения данных:
<template>
<div>
<input type="text" v-model="filterKey" />
</div>
<table>
<thead>
<tr>
<th>A</th>
<th>B</th>
<th>C</th>
</tr>
</thead>
<tbody>
<tr v-for="(obj, index) in filteredData" :key="index">
<td v-for="(value, key) in obj" :key="key">
{{ value }}
</td>
</tr>
</tbody>
</table>
</template>
Данные фильтруются с помощью ввода:
<script>
export default {
props: {
passedData: Array
},
data() {
return {
filterKey: null
};
},
computed: {
filteredData() {
// defining local scope variables
let data = this.passedData;
let filterKey = this.filterKey;
data = data.filter(e => {
// filter by filterKey or this.filterKey
});
return data;
}
}
};
</script>
Мой вопрос относится к let data = ..
и let filterKey = ..
, поскольку filteredData()
запускается при любом изменении filterKey
(определено в data()
), поэтому локальная переменная также обновляется, хотя они не являются "реактивными" в Vue.
Есть ли какое-либо влияние на производительность при определении локальных переменных внутри вычисляемого свойства?Следует ли использовать реактивные переменные из data()
(например, this.filterKey
) непосредственно внутри вычисляемого свойства?