தமிழ்

ரியாக்டின் ஷெட்யூலர் API-இன் ஆற்றலைப் பயன்படுத்தி, பணி முன்னுரிமை மற்றும் டைம் ஸ்லைசிங் மூலம் பயன்பாட்டு செயல்திறனை மேம்படுத்துங்கள். மென்மையான, மேலும் பதிலளிக்கக்கூடிய பயனர் அனுபவத்தை உருவாக்குவது எப்படி என்பதை அறியுங்கள்.

ரியாக்ட் ஷெட்யூலர் API: பணி முன்னுரிமை மற்றும் டைம் ஸ்லைசிங்கில் தேர்ச்சி பெறுதல்

நவீன வலை மேம்பாட்டின் உலகில், தடையற்ற மற்றும் பதிலளிக்கக்கூடிய பயனர் அனுபவத்தை வழங்குவது மிக முக்கியமானது. பயனர் இடைமுகங்களை உருவாக்குவதற்கான ஒரு பிரபலமான ஜாவாஸ்கிரிப்ட் லைப்ரரியான ரியாக்ட், இதை அடைய சக்திவாய்ந்த கருவிகளை வழங்குகிறது. இந்த கருவிகளில் ஒன்று ஷெட்யூலர் API ஆகும், இது பணி முன்னுரிமை மற்றும் டைம் ஸ்லைசிங் மீது நுணுக்கமான கட்டுப்பாட்டை வழங்குகிறது. இந்தக் கட்டுரை, உங்கள் ரியாக்ட் பயன்பாடுகளை மேம்படுத்துவதற்கான அதன் கருத்துக்கள், நன்மைகள் மற்றும் நடைமுறைப் பயன்பாடுகளை ஆராய்ந்து, ரியாக்ட் ஷெட்யூலர் API-இன் நுணுக்கங்களை ஆழமாக ஆராய்கிறது.

ஷெட்யூலிங்கின் தேவையைப் புரிந்துகொள்ளுதல்

தொழில்நுட்ப விவரங்களுக்குள் செல்வதற்கு முன், ஷெட்யூலிங் ஏன் முதலில் அவசியம் என்பதைப் புரிந்துகொள்வது முக்கியம். ஒரு வழக்கமான ரியாக்ட் பயன்பாட்டில், புதுப்பிப்புகள் பெரும்பாலும் ஒத்திசைவாக (synchronously) செயல்படுத்தப்படுகின்றன. இதன் பொருள், ஒரு காம்போனென்ட்டின் நிலை மாறும்போது, ரியாக்ட் உடனடியாக அந்தக் காம்போனென்ட்டையும் அதன் பிள்ளைகளையும் மீண்டும் ரெண்டர் செய்கிறது. இந்த அணுகுமுறை சிறிய புதுப்பிப்புகளுக்கு நன்றாக வேலை செய்தாலும், சிக்கலான காம்போனென்ட்கள் அல்லது கணக்கீட்டு ரீதியாக தீவிரமான பணிகளைக் கையாளும்போது இது சிக்கலாக மாறும். நீண்ட நேரம் இயங்கும் புதுப்பிப்புகள் பிரதான த்ரெட்டைத் தடுக்கலாம், இது மந்தமான செயல்திறனுக்கும் எரிச்சலூட்டும் பயனர் அனுபவத்திற்கும் வழிவகுக்கும்.

ஒரு பயனர் தேடல் பட்டியில் தட்டச்சு செய்யும்போது, அதே நேரத்தில் ஒரு பெரிய தரவுத்தொகுப்பு பெறப்பட்டு ரெண்டர் செய்யப்படும் ஒரு சூழ்நிலையை கற்பனை செய்து பாருங்கள். சரியான ஷெட்யூலிங் இல்லாமல், ரெண்டரிங் செயல்முறை பிரதான த்ரெட்டைத் தடுக்கலாம், இது தேடல் பட்டியின் பதிலளிப்பில் குறிப்பிடத்தக்க தாமதங்களை ஏற்படுத்தும். இங்குதான் ஷெட்யூலர் API உதவுகிறது, இது பணிகளுக்கு முன்னுரிமை அளிக்கவும், கடினமான செயலாக்கத்தின் போதும் பயனர் இடைமுகம் ஊடாடும் வகையில் இருப்பதை உறுதி செய்யவும் நமக்கு உதவுகிறது.

ரியாக்ட் ஷெட்யூலர் API: ஒரு அறிமுகம்

ரியாக்ட் ஷெட்யூலர் API, unstable_ APIகள் என்றும் அழைக்கப்படுகிறது, இது உங்கள் ரியாக்ட் பயன்பாட்டிற்குள் பணிகளின் செயலாக்கத்தைக் கட்டுப்படுத்த உங்களை அனுமதிக்கும் செயல்பாடுகளின் தொகுப்பை வழங்குகிறது. பெரிய, ஒத்திசைவான புதுப்பிப்புகளை சிறிய, ஒத்திசைவற்ற துண்டுகளாக உடைப்பதே இதன் முக்கிய கருத்து. இது பயனர் உள்ளீட்டைக் கையாளுதல் அல்லது அனிமேஷன்களை ரெண்டர் செய்தல் போன்ற பிற பணிகளை இடையில் செருக உலாவியை அனுமதிக்கிறது, இது மேலும் பதிலளிக்கக்கூடிய பயனர் அனுபவத்தை உறுதி செய்கிறது.

முக்கிய குறிப்பு: பெயர் குறிப்பிடுவது போல, unstable_ APIகள் மாற்றத்திற்கு உட்பட்டவை. மிகவும் புதுப்பித்த தகவல்களுக்கு எப்போதும் அதிகாரப்பூர்வ ரியாக்ட் ஆவணங்களைப் பார்க்கவும்.

முக்கிய கருத்துக்கள்:

பணி முன்னுரிமைகள்: முக்கியத்துவத்தின் ஒரு படிநிலை

ஷெட்யூலர் API பல முன்னுரிமை நிலைகளை வரையறுக்கிறது, அவற்றை உங்கள் பணிகளுக்கு ஒதுக்கலாம். இந்த முன்னுரிமைகள் ஷெட்யூலர் பணிகளை செயல்படுத்தும் வரிசையை தீர்மானிக்கின்றன. ரியாக்ட் முன்வரையறுக்கப்பட்ட முன்னுரிமை மாறிலிகளை வழங்குகிறது, அவற்றை நீங்கள் பயன்படுத்தலாம்:

சரியான முன்னுரிமை அளவைத் தேர்ந்தெடுப்பது செயல்திறனை மேம்படுத்துவதற்கு முக்கியமானது. உயர் முன்னுரிமைகளை அதிகமாகப் பயன்படுத்துவது ஷெட்யூலிங்கின் நோக்கத்தையே தோற்கடித்துவிடும், அதே சமயம் முக்கியமான பணிகளுக்கு குறைந்த முன்னுரிமைகளைப் பயன்படுத்துவது தாமதங்களுக்கும் மோசமான பயனர் அனுபவத்திற்கும் வழிவகுக்கும்.

உதாரணம்: பயனர் உள்ளீட்டிற்கு முன்னுரிமை அளித்தல்

உங்களிடம் ஒரு தேடல் பட்டி மற்றும் ஒரு சிக்கலான தரவு காட்சிப்படுத்தல் இருப்பதாகக் கருதுங்கள். காட்சிப்படுத்தல் புதுப்பிக்கப்படும்போதும் தேடல் பட்டி பதிலளிக்கக்கூடியதாக இருப்பதை உறுதிசெய்ய விரும்புகிறீர்கள். தேடல் பட்டி புதுப்பிப்புக்கு அதிக முன்னுரிமையையும், காட்சிப்படுத்தல் புதுப்பிப்புக்கு குறைந்த முன்னுரிமையையும் ஒதுக்குவதன் மூலம் இதை நீங்கள் அடையலாம்.


import { unstable_scheduleCallback as scheduleCallback, unstable_UserBlockingPriority as UserBlockingPriority, unstable_NormalPriority as NormalPriority } from 'scheduler';

function updateSearchTerm(searchTerm) {
  scheduleCallback(UserBlockingPriority, () => {
    // Update the search term in the state
    setSearchTerm(searchTerm);
  });
}

function updateVisualizationData(data) {
  scheduleCallback(NormalPriority, () => {
    // Update the visualization data
    setVisualizationData(data);
  });
}

இந்த எடுத்துக்காட்டில், பயனர் உள்ளீட்டைக் கையாளும் updateSearchTerm செயல்பாடு, UserBlockingPriority உடன் திட்டமிடப்பட்டுள்ளது, இது NormalPriority உடன் திட்டமிடப்பட்டுள்ள updateVisualizationData செயல்பாட்டிற்கு முன் செயல்படுத்தப்படுவதை உறுதி செய்கிறது.

டைம் ஸ்லைசிங்: நீண்ட நேரம் இயங்கும் பணிகளை உடைத்தல்

டைம் ஸ்லைசிங் என்பது நீண்ட நேரம் இயங்கும் பணிகளை சிறிய துண்டுகளாக உடைக்கும் ஒரு நுட்பமாகும், அவை பல ஃபிரேம்களில் செயல்படுத்தப்படலாம். இது பிரதான த்ரெட் நீண்ட காலத்திற்கு தடுக்கப்படுவதைத் தடுக்கிறது, பயனர் உள்ளீடு மற்றும் அனிமேஷன்கள் போன்ற பிற பணிகளை உலாவி மேலும் சுமுகமாகக் கையாள அனுமதிக்கிறது.

ஷெட்யூலர் API unstable_shouldYield செயல்பாட்டை வழங்குகிறது, இது தற்போதைய பணி உலாவிக்கு வழிவிட வேண்டுமா என்பதைத் தீர்மானிக்க உங்களை அனுமதிக்கிறது. பயனர் உள்ளீட்டைக் கையாளுதல் அல்லது காட்சியைக் புதுப்பித்தல் போன்ற பிற பணிகளை உலாவி செய்ய வேண்டியிருந்தால் இந்தச் செயல்பாடு true என வழங்கும். உங்கள் நீண்ட நேரம் இயங்கும் பணிகளுக்குள் அவ்வப்போது unstable_shouldYield ஐ அழைப்பதன் மூலம், உலாவி பதிலளிக்கக்கூடியதாக இருப்பதை நீங்கள் உறுதி செய்யலாம்.

உதாரணம்: ஒரு பெரிய பட்டியலை ரெண்டர் செய்தல்

நீங்கள் ஒரு பெரிய உருப்படிகளின் பட்டியலை ரெண்டர் செய்ய வேண்டிய ஒரு சூழ்நிலையைக் கருதுங்கள். முழு பட்டியலையும் ஒரே ஒத்திசைவான புதுப்பிப்பில் ரெண்டர் செய்வது பிரதான த்ரெட்டைத் தடுத்து செயல்திறன் சிக்கல்களை ஏற்படுத்தும். ரெண்டரிங் செயல்முறையை சிறிய துண்டுகளாக உடைக்க டைம் ஸ்லைசிங்கைப் பயன்படுத்தலாம், இது உலாவி பதிலளிக்கக்கூடியதாக இருக்க அனுமதிக்கிறது.


import { unstable_scheduleCallback as scheduleCallback, unstable_NormalPriority as NormalPriority, unstable_shouldYield as shouldYield } from 'scheduler';

function renderListItems(items) {
  scheduleCallback(NormalPriority, () => {
    let i = 0;
    while (i < items.length) {
      // Render a small batch of items
      for (let j = 0; j < 10 && i < items.length; j++) {
        renderListItem(items[i]);
        i++;
      }

      // Check if we should yield to the browser
      if (shouldYield()) {
        return () => renderListItems(items.slice(i)); // Reschedule the remaining items
      }
    }
  });
}

இந்த எடுத்துக்காட்டில், renderListItems செயல்பாடு ஒரு நேரத்தில் 10 உருப்படிகளின் தொகுப்பை ரெண்டர் செய்கிறது. ஒவ்வொரு தொகுப்பையும் ரெண்டர் செய்த பிறகு, உலாவிக்கு பிற பணிகளைச் செய்ய வேண்டுமா என்பதைச் சரிபார்க்க அது shouldYield ஐ அழைக்கிறது. shouldYield true என வழங்கினால், மீதமுள்ள உருப்படிகளுடன் செயல்பாடு தன்னை மீண்டும் திட்டமிடுகிறது. இது பயனர் உள்ளீட்டைக் கையாளுதல் அல்லது அனிமேஷன்களை ரெண்டர் செய்தல் போன்ற பிற பணிகளை இடையில் செருக உலாவியை அனுமதிக்கிறது, இது மேலும் பதிலளிக்கக்கூடிய பயனர் அனுபவத்தை உறுதி செய்கிறது.

நடைமுறை பயன்பாடுகள் மற்றும் எடுத்துக்காட்டுகள்

ரியாக்ட் ஷெட்யூலர் API பயன்பாட்டின் செயல்திறன் மற்றும் பதிலளிப்பை மேம்படுத்த பரந்த அளவிலான சூழ்நிலைகளுக்குப் பயன்படுத்தப்படலாம். இங்கே சில எடுத்துக்காட்டுகள்:

உதாரணம்: ஒரு டிபவுன்ஸ்டு தேடல் பட்டியை செயல்படுத்துதல்

டிபவுன்சிங் என்பது ஒரு செயல்பாடு செயல்படுத்தப்படும் விகிதத்தைக் கட்டுப்படுத்தப் பயன்படுத்தப்படும் ஒரு நுட்பமாகும். இது தேடல் வினவல்கள் போன்ற பயனர் உள்ளீட்டைக் கையாள்வதற்கு குறிப்பாக பயனுள்ளதாக இருக்கும், அங்கு ஒவ்வொரு விசை அழுத்தத்திலும் தேடல் செயல்பாட்டை இயக்க நீங்கள் விரும்ப மாட்டீர்கள். பயனர் உள்ளீட்டிற்கு முன்னுரிமை அளிக்கும் மற்றும் தேவையற்ற தேடல் கோரிக்கைகளைத் தடுக்கும் ஒரு டிபவுன்ஸ்டு தேடல் பட்டியை செயல்படுத்த ஷெட்யூலர் API பயன்படுத்தப்படலாம்.


import { unstable_scheduleCallback as scheduleCallback, unstable_UserBlockingPriority as UserBlockingPriority, unstable_cancelCallback as cancelCallback } from 'scheduler';
import { useState, useRef, useEffect } from 'react';

function DebouncedSearchBar() {
  const [searchTerm, setSearchTerm] = useState('');
  const [debouncedSearchTerm, setDebouncedSearchTerm] = useState('');
  const scheduledCallbackRef = useRef(null);

  useEffect(() => {
    if (scheduledCallbackRef.current) {
      cancelCallback(scheduledCallbackRef.current);
    }

    scheduledCallbackRef.current = scheduleCallback(UserBlockingPriority, () => {
      setDebouncedSearchTerm(searchTerm);
      scheduledCallbackRef.current = null;
    });

    return () => {
      if (scheduledCallbackRef.current) {
        cancelCallback(scheduledCallbackRef.current);
      }
    };
  }, [searchTerm]);

  // Simulate a search function
  useEffect(() => {
    if (debouncedSearchTerm) {
      console.log('Searching for:', debouncedSearchTerm);
      // Perform your actual search logic here
    }
  }, [debouncedSearchTerm]);

  return (
     setSearchTerm(e.target.value)}
    />
  );
}

export default DebouncedSearchBar;

இந்த எடுத்துக்காட்டில், DebouncedSearchBar காம்போனென்ட் UserBlockingPriority உடன் தேடல் செயல்பாட்டை திட்டமிட scheduleCallback செயல்பாட்டைப் பயன்படுத்துகிறது. முன்பு திட்டமிடப்பட்ட எந்த தேடல் செயல்பாடுகளையும் ரத்து செய்ய cancelCallback செயல்பாடு பயன்படுத்தப்படுகிறது, இது மிக சமீபத்திய தேடல் சொல் மட்டுமே பயன்படுத்தப்படுவதை உறுதி செய்கிறது. இது தேவையற்ற தேடல் கோரிக்கைகளைத் தடுக்கிறது மற்றும் தேடல் பட்டியின் பதிலளிப்பை மேம்படுத்துகிறது.

சிறந்த நடைமுறைகள் மற்றும் கருத்தில் கொள்ள வேண்டியவை

ரியாக்ட் ஷெட்யூலர் API ஐப் பயன்படுத்தும்போது, இந்த சிறந்த நடைமுறைகளைப் பின்பற்றுவது முக்கியம்:

ரியாக்டில் ஷெட்யூலிங்கின் எதிர்காலம்

ரியாக்ட் குழு ரியாக்டின் ஷெட்யூலிங் திறன்களை மேம்படுத்துவதில் தொடர்ந்து பணியாற்றி வருகிறது. ஷெட்யூலர் API மீது கட்டமைக்கப்பட்ட ஒருங்கமைந்த பயன்முறை (Concurrent Mode), ரியாக்ட் பயன்பாடுகளை இன்னும் பதிலளிக்கக்கூடியதாகவும் செயல்திறன் மிக்கதாகவும் மாற்றுவதை நோக்கமாகக் கொண்டுள்ளது. ரியாக்ட் உருவாகும்போது, மேலும் மேம்பட்ட ஷெட்யூலிங் அம்சங்களையும் மேம்பட்ட டெவலப்பர் கருவிகளையும் நாம் எதிர்பார்க்கலாம்.

முடிவுரை

ரியாக்ட் ஷெட்யூலர் API உங்கள் ரியாக்ட் பயன்பாடுகளின் செயல்திறனை மேம்படுத்துவதற்கான ஒரு சக்திவாய்ந்த கருவியாகும். பணி முன்னுரிமை மற்றும் டைம் ஸ்லைசிங் கருத்துக்களைப் புரிந்துகொள்வதன் மூலம், நீங்கள் ஒரு மென்மையான, மேலும் பதிலளிக்கக்கூடிய பயனர் அனுபவத்தை உருவாக்க முடியும். unstable_ APIகள் மாறக்கூடும் என்றாலும், முக்கிய கருத்துக்களைப் புரிந்துகொள்வது எதிர்கால மாற்றங்களுக்கு ஏற்ப உங்களை மாற்றிக்கொள்ளவும், ரியாக்டின் ஷெட்யூலிங் திறன்களின் சக்தியைப் பயன்படுத்தவும் உதவும். ஷெட்யூலர் API ஐப் பயன்படுத்துங்கள் மற்றும் உங்கள் ரியாக்ட் பயன்பாடுகளின் முழு திறனையும் திறக்கவும்!