startTransition
startTransition আপনাকে UI-এর একটি অংশ ব্যাকগ্রাউন্ডে রেন্ডার করতে দেয়।
startTransition(action)রেফারেন্স
startTransition(action) 
startTransition ফাংশন আপনাকে একটি state update কে transition হিসেবে চিহ্নিত করতে দেবে।
import { startTransition } from 'react';
function TabContainer() {
  const [tab, setTab] = useState('about');
  function selectTab(nextTab) {
    startTransition(() => {
      setTab(nextTab);
    });
  }
  // ...
}প্যারামিটার
- action: একটি ফাংশন যেটা এক বা একাধিক- setfunctions কল করার মাধ্যমে কোন state আপডেট করে। React তৎক্ষণাৎ কোন প্যারামিটার ছাড়া- actionকল করে এবং- actionফাংশন কল হবার সময়ে সিঙ্ক্রোনাসভাবে শিডিউল হওয়া সকল state update কে Transition হিসেবে চিহ্নিত করে।- actionএর মধ্যে যেকোনো async কল await করা হলে সেগুলো transition এর অন্তর্ভুক্ত হবে, তবে বর্তমানে- awaitএর পরে যেকোনো- setফাংশনকে একটি অতিরিক্ত- startTransitionদিয়ে wrap করতে হবে (দেখুন ট্রাবলশুটিং)। Transition হিসেবে চিহ্নিত state update গুলো non-blocking হবে এবং অবাঞ্ছিত কোন লোডিং ইনডিকেটর দেখাবে না।
রিটার্ন
startTransition কিছু রিটার্ন করে না।
সতর্কতা
- 
startTransitionএমন কোন পন্থা দেয় না যেটা দিয়ে বুঝা বুঝা যাবে কোন transition পেন্ডীং আছে কি না। যখন transition চলছে সে সময়ে পেন্ডীঙ ইনডিকেটর দেখাবার জন্য আপনার বরংuseTransitionএর দরকার পড়বে।
- 
আপনি একটি আপডেট একটি transition এ wrap করতে পারবেন কেবল যদি আপনার ওই state এর setফাংশনে এক্সেস করার অনুমতি থাকে। যদি আপনি কোন prop বা কাস্টম হুকের রেসপন্স হিসেবে একটি transition শুরু করতে চান, বরংuseDeferredValueব্যবহার করুন।
- 
আপনি startTransitionএ যে ফাংশন পাস করবেন সেটা তৎক্ষণাৎ কল হয়, এবং এটা এক্সিকিউট হবার সময়ে চলমান সকল state update কে Transition হিসেবে চিহ্নিত করে। আপনি যদিsetTimeoutএর মধ্যে state update করার চেষ্টা করেন, তাহলে সেগুলো Transition হিসেবে চিহ্নিত হবে না।
- 
যেকোনো async request এর পরে state update গুলোকে Transition হিসেবে চিহ্নিত করতে আপনাকে অবশ্যই আরেকটি startTransitionদিয়ে wrap করতে হবে। এটি একটি পরিচিত সীমাবদ্ধতা যা আমরা ভবিষ্যতের কোন রিলিজে ঠিক করবো (দেখুন ট্রাবলশুটিং)।
- 
Transition হিসেবে চিহ্নিত একটি state আপডেট অন্যান্য state update দ্বারা বাধাপ্রাপ্ত হবে। উদাহরণস্বরূপ, আপনি যদি একটি transition এর মধ্যে একটি চার্ট component আপডেট করেন, কিন্তু তার পরি চার্ট re-render এর মধ্যে থাকা অবস্থায় একটি ইনপুট ফিল্ডে টাইপ করা শুরু করেন, React ইনপুট state আপডেট হ্যান্ডল করার পর চার্ট component এর রেন্ডারিং এর কাজ পুনরায় শুরু করবে। 
- 
Transition আপডেট টেক্সট ইনপুট নিয়ন্ত্রণ করার জন্য ব্যবহার করা যাবে না। 
- 
যদি একাধিক Transition চলমান থাকে, React বর্তমানে সেগুলোকে একসাথে ব্যাচ করে। এটা একটা সীমাবদ্ধতা যা ভবিষ্যতের কোন রিলিজে সরানো হতে পারে। 
ব্যবহার
একটি state update কে non-blocking transition হিসেবে চিহ্নিত করা
আপনি একটি state update কে startTransition কলের মধ্যে wrap করার মাধ্যমে transition হিসেবে চিহ্নিত করতে পারেনঃ
import { startTransition } from 'react';
function TabContainer() {
  const [tab, setTab] = useState('about');
  function selectTab(nextTab) {
    startTransition(() => {
      setTab(nextTab);
    });
  }
  // ...
}Transitions আপনাকে ধীরগতির ডিভাইসগুলোতেও ইউজার ইন্টারফেস আপডেট রেস্পন্সিভ রাখার সুযোগ দেয়।
Transition এর সাথে, একতা re-render এর মধ্যে আপনার UI রেস্পন্সিভ থাকে। উদাহরণস্বরূপ, যদি একজন ব্যবহারকারী একটা ট্যাবে ক্লিক করে এবং এর পরেই তার ইচ্ছা পরিবর্তন করে অন্য একটি ইয়াব ক্লিক করে, সেটা তারা প্রথম re-render শেষ হবার অপেক্ষা না করেই করতে পারবেন।