Back to questions
Middle
2
В резюме указана защита от race condition через AbortController. Как именно вы интегрируете отмену запросов в жизненный цикл компонента Vue? Например, если пользователь ушёл со страницы до завершения запроса, как это реализовать со сложной логикой Pinia?
Companies where asked
Магнут
Answer from AI
sobes.tech AI
Для предотвращения race condition и утечек памяти при отмене запросов в Vue с использованием Pinia и AbortController можно сделать так:
- В компоненте создайте экземпляр
AbortControllerпри монтировании. - Перед отправкой запроса передайте
signalиз этого контроллера в fetch/Axios. - В хуке
beforeUnmountвызывайтеabort()для отмены всех незавершённых запросов. - Если логика сложная и запросы инициируются из Pinia, можно хранить
AbortControllerв состоянии стора или передавать его в экшены.
Пример:
import { defineComponent, onBeforeUnmount } from 'vue'
import { useStore } from '@/stores/myStore'
export default defineComponent({
setup() {
const store = useStore()
const controller = new AbortController()
store.fetchData({ signal: controller.signal })
onBeforeUnmount(() => {
controller.abort() // отменяем запрос при уходе со страницы
})
}
})
В Pinia:
import { defineStore } from 'pinia'
import axios from 'axios'
export const useStore = defineStore('main', {
actions: {
async fetchData({ signal }) {
try {
const response = await axios.get('/api/data', { signal })
this.data = response.data
} catch (e) {
if (axios.isCancel(e)) {
console.log('Запрос отменён')
} else {
throw e
}
}
}
}
})
Такой подход гарантирует, что при уходе пользователя со страницы все незавершённые запросы будут отменены, предотвращая race condition и ненужные обновления состояния.