શરતી રેન્ડરિંગ
તમારા કમ્પોનેન્ટસને ઘણીવાર વિવિધ શરતો અનુસાર અલગ-અલગ વસ્તુઓ દર્શાવવાની જરૂર પડશે. React માં, તમે જાવાસ્ક્રિપ્ટ ની if
સ્ટેટમેન્ટ્સ, &&
, અને ? :
ઓપરેટર્સનો ઉપયોગ કરીને શરતી રીતે JSX રેન્ડર કરી શકો છો.
You will learn
- શરત પર આધાર રાખી અલગ JSX કેવી રીતે રીટર્ન કરવી.
- JSX ના ભાગને શરતી રીતે કેવી રીતે ઉમેરવો અથવા કાઢી નાખવો.
- React કોડબેઝમાં તમને મળતી સામાન્ય શરત આધારિત સિન્ટેક્સ શોર્ટકટ્સ.
શરતી રીતે JSX રીટર્ન કરવું
માનો કે તમારી પાસે PackingList
નામનું કમ્પોનેન્ટ છે, જે અમુક Item
s રેન્ડર કરે છે, જેમને packed તરીકે અથવા not packed તરીકે ચિહ્નિત કરી શકાય છે:
function Item({ name, isPacked }) { return <li className="item">{name}</li>; } export default function PackingList() { return ( <section> <h1>Sally Ride's Packing List</h1> <ul> <Item isPacked={true} name="Space suit" /> <Item isPacked={true} name="Helmet with a golden leaf" /> <Item isPacked={false} name="Photo of Tam" /> </ul> </section> ); }
ધ્યાન આપો કે અમુક Item
કમ્પોનેન્ટસમાં isPacked
prop true
તરીકે સેટ છે, જ્યારે અમુકમાં false
છે. જો isPacked={true}
હોય, તો packed કરેલા items માટે તમે ચેકમાર્ક (✅) કરી શકો છો.
તમે આને if
/else
સ્ટેટમેન્ટ તરીકે આ રીતે લખી શકો છો:
if (isPacked) {
return <li className="item">{name} ✅</li>;
}
return <li className="item">{name}</li>;
જો isPacked
prop true
છે, તો આ કોડ અલગ JSX tree રીટર્ન કરશે. આ બદલાવના કારણે, અમુક items ના અંતે ચેકમાર્ક(✅) જોવા મળશે.
function Item({ name, isPacked }) { if (isPacked) { return <li className="item">{name} ✅</li>; } return <li className="item">{name}</li>; } export default function PackingList() { return ( <section> <h1>Sally Ride's Packing List</h1> <ul> <Item isPacked={true} name="Space suit" /> <Item isPacked={true} name="Helmet with a golden leaf" /> <Item isPacked={false} name="Photo of Tam" /> </ul> </section> ); }
પ્રત્યેક કિસ્સામાં શું રીટર્ન થાય છે તે એડિટ કરવાનો પ્રયત્ન કરો, અને પરિણામ કેવી રીતે બદલાય છે તે જુઓ!
નોધો કે તમે જાવાસ્ક્રિપ્ટ ના if
અને return
સ્ટેટમેન્ટ્સ સાથે ભેગું લોજિક બનાવો છો. React માં, કંટ્રોલ ફ્લો (જેમ કે શરતો) જાવાસ્ક્રિપ્ટ દ્વારા નિયંત્રિત થાય છે.
શરતી રીતે null
સાથે કશું જ રીટર્ન કરશે નહીં.
અમુક પરિસ્થિતિઓમાં, તમે કશું પણ રેન્ડર કરવા માંગતા નથી. ઉદાહરણ તરીકે, માનો કે તમે packed કરેલ items દર્શાવવા માંગતા નથી. એક કમ્પોનેન્ટને કંઈક રીટર્ન કરવું જરૂરી છે. આ કિસ્સામાં, તમે null
રીટર્ન કરી શકો છો:
if (isPacked) {
return null;
}
return <li className="item">{name}</li>;
જો isPacked
true છે, તો કમ્પોનેન્ટ કશું પણ રીટર્ન નહીં કરે, એટલે કે null
. અન્યથા, તે JSX રેન્ડર કરવા માટે રીટર્ન કરશે.
function Item({ name, isPacked }) { if (isPacked) { return null; } return <li className="item">{name}</li>; } export default function PackingList() { return ( <section> <h1>Sally Ride's Packing List</h1> <ul> <Item isPacked={true} name="Space suit" /> <Item isPacked={true} name="Helmet with a golden leaf" /> <Item isPacked={false} name="Photo of Tam" /> </ul> </section> ); }
વ્યવહારમાં, એક કમ્પોનેન્ટમાંથી null
રીટર્ન કરવું સામાન્ય નથી કારણ કે તે તેને રેન્ડર કરવાનો પ્રયાસ કરનાર ડેવલપરને આશ્ચર્યમાં મૂકશે. વધારે વાર, તમે પેરેન્ટ કમ્પોનેન્ટના JSX માં કમ્પોનેન્ટને શરતસર શામેલ કરવા કે બહાર કરવા પસંદ કરશો. તે કેવી રીતે કરવું તે અહીં છે!
શરતી રીતે JSX સમાવિષ્ટ કરવું
પહેલાના ઉદાહરણમાં, તમે નિયંત્રિત કર્યું હતું કે કયું (અથવા કંઈ નહીં!) JSX tree કમ્પોનેન્ટ દ્વારા રીટર્ન થશે. તમે કદાચ રેન્ડર આઉટપુટમાં થોડી પુનરાવર્તન જોઈ હશે.
<li className="item">{name} ✅</li>
આ ખૂબ સમાન છે
<li className="item">{name}</li>
બન્ને શરતી શાખાઓ <li className="item">...</li>
રીટર્ન કરે છે.
if (isPacked) {
return <li className="item">{name} ✅</li>;
}
return <li className="item">{name}</li>;
જોકે આ પુનરાવૃત્તિ નુકસાનકારક નથી, તે તમારા કોડને જાળવવા માટે મુશ્કેલ બનાવી શકે છે. જો તમારે className
બદલવું પડે, તો તમારે તમારા કોડની બે અલગ અલગ જગ્યાએ આ ફેરફાર કરવો પડશે! આવી પરિસ્થિતિમાં, તમે તમારા કોડને વધુ DRY બનાવવા માટે શરતી રીતે થોડું JSX સામેલ કરી શકો છો.
શરતી (ટર્નરી) ઓપરેટર (? :
)
જાવાસ્ક્રિપ્ટ માં શરતી એક્સપ્રેશન લખવા માટે સંક્ષિપ્ત સિનટેક્સ છે - શરતી ઓપરેટર
અથવા “ટર્નરી ઓપરેટર”.
આના બદલે:
if (isPacked) {
return <li className="item">{name} ✅</li>;
}
return <li className="item">{name}</li>;
તમે આ લખી શકો છો:
return (
<li className="item">
{isPacked ? name + ' ✅' : name}
</li>
);
તમે આ રીતે વાંચી શકો છો: “જો isPacked
true છે, તો (?
) name + ' ✅'
રેન્ડર કરો, અન્યથા (:
) name
રેન્ડર કરો”.
Deep Dive
જો તમે ઓબ્જેક્ટ-ઓરિએન્ટેડ પ્રોગ્રામિંગ પૃષ્ઠભૂમિમાંથી આવી રહ્યા છો, તો તમે માની શકો છો કે ઉપરના બંને ઉદાહરણો થોડા અલગ છે , કારણ કે એક <li>
ના બે અલગ-અલગ “instances” બનાવે છે. પણ JSX એલીમેન્ટ્સ “instances” નથી, કારણ કે તે કોઈ આંતરિક state ધરાવતા નથી અને એ સાચા DOM નોડ્સ નથી. તે લાઇટવેઇટ વર્ણનાઓ છે, જેમ કે બ્લૂપ્રિન્ટ. તેથી આ બે ઉદાહરણો વાસ્તવમાં સંપૂર્ણ રીતે સમાન છે. સ્ટેટ જાળવવું અને ફરીથી સેટ કરવું એ કેવી રીતે કામ કરે છે તેની વિગતવાર માહિતી આપવામાં આવી છે.
હવે માનો કે તમે પૂર્ણ થયેલા item ના ટેક્સ્ટને બીજાં HTML ટૅગ, જેમ કે <del>
,માં વાપરવા માંગો છો જેથી તે સ્ટ્રાઇક થતું દેખાય. દરેક કિસ્સામાં વધુ JSX ને સારી રીતે nested રીતે ઉમેરવા માટે તમે newline અને parentheses ઉમેરી શકો છો.
function Item({ name, isPacked }) { return ( <li className="item"> {isPacked ? ( <del> {name + ' ✅'} </del> ) : ( name )} </li> ); } export default function PackingList() { return ( <section> <h1>Sally Ride's Packing List</h1> <ul> <Item isPacked={true} name="Space suit" /> <Item isPacked={true} name="Helmet with a golden leaf" /> <Item isPacked={false} name="Photo of Tam" /> </ul> </section> ); }
આ શૈલી સરળ શરતો માટે સારી રીતે કામ કરે છે, પરંતુ તેને મર્યાદિત પ્રમાણમાં જ ઉપયોગ કરો. જો તમારા કમ્પોનેન્ટમાં ખૂબ Nested શરતી માર્કઅપને કારણે ગૂંચવણ થાય, તો વસ્તુઓને સ્પષ્ટ કરવા માટે ચાઈલ્ડ કમ્પોનેન્ટને અલગ કાઢવાનું વિચારવું જોઈએ. React માં, માર્કઅપ તમારા કોડનો જ ભાગ હોય છે, તેથી તમે કૉમ્પ્લેક્સ એક્સપ્રેશન્સ ને સરળ બનાવવા માટે વેરીએબલ્સ અને ફંક્શન્સ જેવા ટૂલ્સનો ઉપયોગ કરી શકો છો.
લોજિકલ AND ઑપરેટર (&&
)
React કમ્પોનેન્ટસમાં તમે સામાન્ય રીતે જાવાસ્ક્રિપ્ટ લોજિકલ AND (&&
) ઓપરેટર નો ઉપયોગ કરશો.આનો ઉપયોગ ત્યારે થાય છે જ્યારે તમારી શરત સાચી હોય ત્યારે અમુક JSX રેન્ડર કરવા માંગતા હો, અથવા અન્યથા કશું જ રેન્ડર ન કરો. &&
ની મદદથી, તમે isPacked
true
હોય ત્યારે જ ચેકમાર્ક શરતી રીતે રેન્ડર કરી શકો:
return (
<li className="item">
{name} {isPacked && '✅'}
</li>
);
તમે આને આ રીતે વાંચી શકો છો “જો isPacked
હોય, તો (&&
) ચેકમાર્ક રેન્ડર કરો, અન્યથા કશું જ રેન્ડર ન કરો”.
આ છે તેનું કાર્યરત ઉદાહરણ:
function Item({ name, isPacked }) { return ( <li className="item"> {name} {isPacked && '✅'} </li> ); } export default function PackingList() { return ( <section> <h1>Sally Ride's Packing List</h1> <ul> <Item isPacked={true} name="Space suit" /> <Item isPacked={true} name="Helmet with a golden leaf" /> <Item isPacked={false} name="Photo of Tam" /> </ul> </section> ); }
એક જાવાસ્ક્રિપ્ટ && એક્સપ્રેશન્સ એ તેના જમણા ભાગની value પરત કરે છે (આપના કેસમાં, ચેકમાર્ક), જો ડાબો ભાગ (આપની શરત) true
હોય. પરંતુ જો શરત false
હોય, તો આખી expression false
બની જાય છે. React false
ને JSX tree માં “ખાલી જગ્યા” તરીકે માને છે, જેમ કે null
અથવા undefined
, અને તેની જગ્યાએ કશું જ રેન્ડર કરતું નથી.
JSX ને શરતી રીતે વેરીએબલને ફાળવવું
જ્યારે શોર્ટકટ્સ સરળ કોડ લખવામાં અવરોધ રૂપ બને ત્યારે, if
સ્ટેટમેન્ટ અને વેરીએબલનો ઉપયોગ કરવાનો પ્રયત્ન કરો. તમે let
વડે વ્યાખ્યાયિત વેરીએબલ્સને ફરી ફાળવી શકો છો, એટલે કે, તમે દર્શાવવા માંગતા ડિફોલ્ટ કન્ટેન્ટથી પ્રારંભ કરો, જેમ કે name:
let itemContent = name;
if
સ્ટેટમેન્ટનો ઉપયોગ કરીને JSX એક્સપ્રેશનને itemContent
માં ફરી ફાળવો જો isPacked
true
હોય:
if (isPacked) {
itemContent = name + " ✅";
}
કૌંસો (curly braces) “જાવાસ્ક્રિપ્ટમાં વિન્ડો” ખોલે છે. રીટર્ન કરેલા JSX tree માં કૌંસ સાથે વેરિએબલ એમ્બેડ કરો,અને અગાઉ ગણવામાં આવેલ એક્સપ્રેશન JSX ની અંદર nest કરો:
<li className="item">
{itemContent}
</li>
આ શૈલી સૌથી વધારે વર્બોઝ (Verbose) છે, પરંતુ તે સૌથી વધુ લવચીક પણ છે. અહીં તે પ્રયોગમાં છે:
function Item({ name, isPacked }) { let itemContent = name; if (isPacked) { itemContent = name + " ✅"; } return ( <li className="item"> {itemContent} </li> ); } export default function PackingList() { return ( <section> <h1>Sally Ride's Packing List</h1> <ul> <Item isPacked={true} name="Space suit" /> <Item isPacked={true} name="Helmet with a golden leaf" /> <Item isPacked={false} name="Photo of Tam" /> </ul> </section> ); }
અગાઉની જેમ, આ માત્ર ટેક્સ્ટ માટે જ નહીં પરંતુ મનચાહું JSX માટે પણ કાર્ય કરે છે:
function Item({ name, isPacked }) { let itemContent = name; if (isPacked) { itemContent = ( <del> {name + " ✅"} </del> ); } return ( <li className="item"> {itemContent} </li> ); } export default function PackingList() { return ( <section> <h1>Sally Ride's Packing List</h1> <ul> <Item isPacked={true} name="Space suit" /> <Item isPacked={true} name="Helmet with a golden leaf" /> <Item isPacked={false} name="Photo of Tam" /> </ul> </section> ); }
જો તમે જાવાસ્ક્રિપ્ટથી પરિચિત નથી, તો આ શૈલીઓની વિવિધતા પ્રથમ દ્રષ્ટિએ બહુ જટિલ લાગી શકે છે. તેમ છતાં, તેને શીખવાથી તમને કોઇ પણ જાવાસ્ક્રિપ્ટ કોડ — અને ફક્ત React કમ્પોનેન્ટસ જ નહિ — વાંચવા અને લખવામાં મદદ મળશે! શરૂઆતમાં જે શૈલી તમને યોગ્ય લાગતી હોય, તે પસંદ કરો, અને પછી જો બીજાની કાર્યપદ્ધતિ ભૂલી જાવ તો આ સંદર્ભ ફરીથી તપાસો.
Recap
- React માં, તમે branching logic ને જાવાસ્ક્રિપ્ટની મદદથી નિયંત્રિત કરી શકો છો.
- તમે
if
statement નો ઉપયોગ કરીને JSX શરતી રીતે રીટર્ન કરી શકો છો. - તમે શરતો મુજબ JSX ને વેરીએબલમાં સાચવી શકો છો અને પછી તેને બીજા JSX માં curly braces નો ઉપયોગ કરીને સમાવિષ્ટ કરી શકો છો.
- JSX માં,
{cond ? <A /> : <B />}
નો અર્થ છે “જોcond
true હોય, તો<A />
દર્શાવો, નહીં તો<B />
”. - JSX માં,
{cond && <A />}
નો અર્થ છે “જોcond
true હોય, તો<A />
દર્શાવો, નહીં તો કંઈ પણ ન દર્શાવો”. - આ શોર્ટકટ્સ સામાન્ય છે, પરંતુ તમે plain
if
નો ઉપયોગ કરવાની ઇચ્છા કરો છો તો તે તમારી ઇચ્છા છે.
Challenge 1 of 3: અપૂર્ણ items માટે આઇકન બતાવવા ? :
નો ઉપયોગ કરો.
cond ? a : b
શરતનો ઉપયોગ કરીને, જયારે isPacked
false હોય ત્યારે ❌ દર્શાવો.
function Item({ name, isPacked }) { return ( <li className="item"> {name} {isPacked && '✅'} </li> ); } export default function PackingList() { return ( <section> <h1>Sally Ride's Packing List</h1> <ul> <Item isPacked={true} name="Space suit" /> <Item isPacked={true} name="Helmet with a golden leaf" /> <Item isPacked={false} name="Photo of Tam" /> </ul> </section> ); }