cacheSignal
cache() lifetime முடிந்தது எப்போது என்பதை அறிய cacheSignal அனுமதிக்கிறது.
const signal = cacheSignal();Reference
cacheSignal
AbortSignal பெற cacheSignal-ஐ அழைக்கவும்.
import {cacheSignal} from 'react';
async function Component() {
await fetch(url, { signal: cacheSignal() });
}React rendering முடித்ததும், AbortSignal abort செய்யப்படும். இனி தேவையில்லாத in-flight work-ஐ cancel செய்ய இது அனுமதிக்கிறது.
பின்வரும் நேரங்களில் rendering முடிந்ததாக கருதப்படும்:
- React rendering-ஐ வெற்றிகரமாக முடித்தது
- Render abort செய்யப்பட்டது
- Render தோல்வியடைந்தது
Parameters
இந்த function எந்த parameters-யும் ஏற்காது.
Returns
Rendering நடக்கும் போது அழைத்தால் cacheSignal ஒரு AbortSignal return செய்யும். இல்லையெனில் cacheSignal() null return செய்யும்.
Caveats
cacheSignalதற்போது React Server Components-இல் மட்டுமே பயன்படுத்தப்பட உள்ளது. Client Components-இல் இது எப்போதும்nullreturn செய்யும். எதிர்காலத்தில், client cache refresh அல்லது invalidate ஆகும் போது Client Component-க்கும் இது பயன்படுத்தப்படும். Client-இல் இது எப்போதும் null தான் என்று நீங்கள் கருதக்கூடாது.- Rendering-க்கு வெளியே அழைத்தால், தற்போதைய scope நிரந்தரமாக cached இல்லை என்பதை தெளிவாக்க
cacheSignalnullreturn செய்யும்.
Usage
In-flight requests-ஐ cancel செய்தல்
In-flight requests-ஐ abort செய்ய cacheSignal-ஐ அழைக்கவும்.
import {cache, cacheSignal} from 'react';
const dedupedFetch = cache(fetch);
async function Component() {
await dedupedFetch(url, { signal: cacheSignal() });
}React rendering முடித்த பிறகு errors-ஐ புறக்கணித்தல்
ஒரு function throw செய்தால், அது cancellation காரணமாக இருக்கலாம் (உதா. Database connection மூடப்பட்டுள்ளது). Error cancellation காரணமா அல்லது உண்மையான error-ஆ என்பதைச் சரிபார்க்க aborted property-ஐப் பயன்படுத்தலாம். Cancellation காரணமாக ஏற்பட்ட errors-ஐ புறக்கணிக்க நீங்கள் விரும்பலாம்.
import {cacheSignal} from "react";
import {queryDatabase, logError} from "./database";
async function getData(id) {
try {
return await queryDatabase(id);
} catch (x) {
if (!cacheSignal()?.aborted) {
// only log if it's a real error and not due to cancellation
logError(x);
}
return null;
}
}
async function Component({id}) {
const data = await getData(id);
if (data === null) {
return <div>No data available</div>;
}
return <div>{data.name}</div>;
}