కంపోనెంట్లను ఇంపోర్ట్ మరియు ఎక్స్పోర్ట్ చేయడం
కంపోనెంట్ల మ్యాజిక్ వాటి రీయూజబులిటీలో ఉంది: మీరు ఇతర కంపోనెంట్లతో కలిపిన కంపోనెంట్లను సృష్టించవచ్చు. కానీ మీరు మరింత ఎక్కువ కంపోనెంట్లను నెస్ట్ చేస్తూ ఉండగా, వాటిని వేర్వేరు ఫైళ్లలో విభజించడం అనేది సాధారణంగా సరియిన నిర్ణయం అవుతుంది. ఇది మీ ఫైళ్లను సులభంగా స్కాన్ చేయగలిగేలా చేస్తుంది మరియు కంపోనెంట్లను మరిన్ని ప్రదేశాలలో రీయూజబుల్ చేసుకునేందుకు అనుకూలంగా ఉంటుంది.
You will learn
- రూట్ కంపోనెంట్ ఫైల్ అంటే ఏమిటి
- కంపోనెంట్లను ఇంపోర్ట్ మరియు ఎక్స్పోర్ట్ చేయడం ఎలా
- డిఫాల్ట్ మరియు నేమ్డ్ ఇంపోర్ట్ మరియు ఎక్స్పోర్ట్ ఎప్పుడు ఉపయోగించాలి
- ఒక ఫైల్ నుండి అనేక కంపోనెంట్లను ఇంపోర్ట్ మరియు ఎక్స్పోర్ట్ చేయడం ఎలా
- కంపోనెంట్లను అనేక ఫైళ్లలో ఎలా విభజించాలి
రూట్ కంపోనెంట్ ఫైల్
మీ మొదటి కంపోనెంట్ లో, మీరు Profile అనే కంపోనెంట్ మరియు దానిని రెండర్ చేసే Gallery అనే కంపోనెంట్ సృష్టించారు:
function Profile() { return ( <img src="https://i.imgur.com/MK3eW3As.jpg" alt="Katherine Johnson" /> ); } export default function Gallery() { return ( <section> <h1>Amazing scientists</h1> <Profile /> <Profile /> <Profile /> </section> ); }
ఇవి ప్రస్తుతం రూట్ కంపోనెంట్ ఫైల్ లో ఉన్నాయి, ఈ ఉదాహరణలో App.js. మీ సెటప్పై ఆధారపడి, మీ రూట్ కంపోనెంట్ వేరే ఫైల్లో ఉండవచ్చు. మీరు Next.js లాంటి ఫైల్ ఆధారిత రూటింగ్ ఫ్రేమ్వర్క్ ఉపయోగిస్తే, ప్రతి పేజీకి మీ రూట్ కంపోనెంట్ వేరుగా ఉంటుంది.
కంపోనెంట్లను ఎక్స్పోర్ట్ మరియు ఇంపోర్ట్ చేయడం
మీరు భవిష్యత్తులో ల్యాండింగ్ స్క్రీన్ను మార్చి అక్కడ ఒక సైన్స్ పుస్తకాల జాబితా ఉంచాలని అనుకుంటే? లేదా అన్ని ప్రొఫైల్స్ను మరొకచోట ఉంచాలనుకుంటే? Gallery మరియు Profile ను రూట్ కంపోనెంట్ ఫైల్ నుండి బయటకు తరలించడం అవసరం. ఇది వాటిని మరింత మాడ్యులర్గా, ఇతర ఫైళ్లలో రీయూజబుల్ చేయడానికి అనుకూలంగా చేస్తుంది. కంపోనెంట్ను తరలించడానికి మూడు దశలు ఉన్నాయి:
- కొత్త JS ఫైల్ ను కంపోనెంట్లను ఉంచడానికి సృష్టించండి.
- ఆ ఫైల్ నుండి మీ ఫంక్షన్ కంపోనెంట్ను ఎక్స్పోర్ట్ చేయండి (డిఫాల్ట్ లేదా నేమ్డ్ ఎక్స్పోర్ట్స్ను ఉపయోగించి).
- మీరు ఆ కంపోనెంట్ను ఉపయోగించే ఫైల్లో దాన్ని ఇంపోర్ట్ చేసుకోండి (తదనుగుణంగా డిఫాల్ట్ లేదా నేమ్డ్ ఇంపోర్ట్ల పద్ధతిని ఉపయోగించండి).
ఇక్కడ Profile మరియు Gallery రెండూ App.js నుండి బయటకు తీసి కొత్త ఫైల్ Gallery.js లో ఉంచబడ్డాయి. ఇప్పుడు మీరు App.js లో Gallery.js నుండి Gallery ని ఇంపోర్ట్ చేసుకోవచ్చు:
import Gallery from './Gallery.js'; export default function App() { return ( <Gallery /> ); }
ఈ ఉదాహరణ ఇప్పుడు రెండు కంపోనెంట్ ఫైళ్లలో విభజించబడింది:
Gallery.js:Profileకంపోనెంట్ను డిఫైన్ చేస్తుంది, ఇది అదే ఫైల్లో మాత్రమే ఉపయోగించబడుతుంది మరియు ఎక్స్పోర్ట్ చేయబడదు.Galleryకంపోనెంట్ను డిఫాల్ట్ ఎక్స్పోర్ట్ గా ఎక్స్పోర్ట్ చేస్తుంది.
App.js:Gallery.jsనుండిGalleryను డిఫాల్ట్ ఇంపోర్ట్ గా ఇంపోర్ట్ చేసుకుంటుంది.- రూట్ App కంపోనెంట్ను డిఫాల్ట్ ఎక్స్పోర్ట్ గా ఎక్స్పోర్ట్ చేస్తుంది.
Deep Dive
JavaScript లో వాల్యూస్ ను ఎక్స్పోర్ట్ చేయడానికి రెండు ప్రధాన మార్గాలు ఉన్నాయి: డిఫాల్ట్ ఎక్స్పోర్ట్స్ మరియు నేమ్డ్ ఎక్స్పోర్ట్స్. ఇంతవరకు, మా ఉదాహరణలు కేవలం డిఫాల్ట్ ఎక్స్పోర్ట్స్ మాత్రమే ఉపయోగించాయి. కానీ మీరు వాటిలో ఏదైనా ఒకటి లేదా రెండూ ఉపయోగించవచ్చు. ఒక ఫైల్లో కేవలం ఒకే ఒక డిఫాల్ట్ ఎక్స్పోర్ట్ ఉండవచ్చు, కానీ మీరు అనుకున్నంత నేమ్డ్ ఎక్స్పోర్ట్స్ ఉంచవచ్చు.
మీరు మీ కంపోనెంట్ను ఎక్స్పోర్ట్ చేసే విధానం మీరు దాన్ని ఎలా ఇంపోర్ట్ చేయాలో నిర్ణయిస్తుంది. మీరు డిఫాల్ట్ ఎక్స్పోర్ట్ ను నేమ్డ్ ఎక్స్పోర్ట్ లాగా ఇంపోర్ట్ చేయాలని ప్రయత్నిస్తే, ఎర్రర్ వస్తుంది! ఈ చార్ట్ మీకు సహాయం చేస్తుంది:
| సింటాక్స్ | ఎక్స్పోర్ట్ స్టేట్మెంట్ | ఇంపోర్ట్ స్టేట్మెంట్ |
|---|---|---|
| డిఫాల్ట్ | export default function Button() {} | import Button from './Button.js'; |
| నేమ్డ్ | export function Button() {} | import { Button } from './Button.js'; |
మీరు ఒక డిఫాల్ట్ ఇంపోర్ట్ రాస్తే, మీరు import తర్వాత ఏ పేరైనా ఉంచవచ్చు. ఉదాహరణకు, మీరు import Banana from './Button.js' అని రాయవచ్చు మరియు అది మీకు అదే డిఫాల్ట్ ఎక్స్పోర్ట్ ని అందిస్తుంది. ప్రతికూలంగా, నేమ్డ్ ఇంపోర్ట్ లో, పేరు రెండు వైపులా ఒకటే ఉండాలి. అందుకే వాటిని నేమ్డ్ ఇంపోర్ట్లు అని పిలుస్తారు!
మొత్తం ఫైల్ ఒకే ఒక కంపోనెంట్ను ఎక్స్పోర్ట్ చేస్తే డిఫాల్ట్ ఎక్స్పోర్ట్స్ సాధారణంగా ఉపయోగిస్తారు, మరియు అది అనేక కంపోనెంట్లు మరియు వాల్యూస్ను ఎక్స్పోర్ట్ చేస్తే, నేమ్డ్ ఎక్స్పోర్ట్స్ ఉపయోగిస్తారు. మీరు ఎంచుకున్న కోడింగ్ స్టైల్ ఏది అయినా, ఎల్లప్పుడూ మీ కంపోనెంట్ ఫంక్షన్స్ మరియు వాటిని కలిగి ఉన్న ఫైళ్ళకు అర్థవంతమైన పేర్లను ఇవ్వండి. పేరులు లేని కంపోనెంట్లు, ఉదాహరణకి export default () => {}, డీబగ్గింగ్ను కష్టతరంగా చేస్తాయి కనుక వాటిని ఉపయోగించడం ప్రోత్సహించదు.
ఒకే ఫైల్ నుండి అనేక కంపోనెంట్లను ఎక్స్పోర్ట్ మరియు ఇంపోర్ట్ చేయడం
మీరు gallery కి బదులు ఒకే Profile చూపించాలని కోరుకుంటే ఏమిటి? మీరు Profile కంపోనెంట్ను కూడా ఎక్స్పోర్ట్ చేయవచ్చు. కానీ Gallery.js లో ఇప్పటికే డిఫాల్ట్ ఎక్స్పోర్ట్ ఉంది, మరియు మీరు రెండు డిఫాల్ట్ ఎక్స్పోర్ట్స్ కలిగి ఉండలేరు. మీరు ఒక కొత్త ఫైల్ను డిఫాల్ట్ ఎక్స్పోర్ట్తో సృష్టించవచ్చు, లేదా Profile కోసం నేమ్డ్ ఎక్స్పోర్ట్ను జోడించవచ్చు. ఒక ఫైల్లో కేవలం ఒక డిఫాల్ట్ ఎక్స్పోర్ట్ ఉండవచ్చు, కానీ అనేక నేమ్డ్ ఎక్స్పోర్ట్స్ ఉండవచ్చు!
మొదట,Profile ని Gallery.js నుండి ఎక్స్పోర్ట్ చేయండి, నేమ్డ్ ఎక్స్పోర్ట్ ద్వారా (డిఫాల్ట్ కీవర్డ్ను ఉపయోగించకుండా):
export function Profile() {
// ...
}తర్వాత, App.js లో Profile ని Gallery.js నుండి ఇంపోర్ట్ చేయండి, నేమ్డ్ ఇంపోర్ట్ ద్వారా (కర్లీ బ్రేసెస్తో):
import { Profile } from './Gallery.js';చివరగా, App కంపోనెంట్ నుండి <Profile /> ని రెండర్ చేయండి:
export default function App() {
return <Profile />;
}ఇప్పుడు Gallery.js లో రెండు ఎక్స్పోర్ట్లు ఉన్నాయి: ఒక డిఫాల్ట్ Gallery ఎక్స్పోర్ట్, మరియు ఒక నేమ్డ్ Profile ఎక్స్పోర్ట్. App.js రెండింటినీ ఇంపోర్ట్ చేసుకుంటుంది. ఈ ఉదాహరణలో <Profile /> ను <Gallery /> గా ఎడిట్ చేసి, మళ్ళీ వెనక్కి మార్చడానికి ప్రయత్నించండి:
import Gallery from './Gallery.js'; import { Profile } from './Gallery.js'; export default function App() { return ( <Profile /> ); }
ఇప్పుడు మీరు డిఫాల్ట్ మరియు నేమ్డ్ ఎక్స్పోర్ట్ల మిశ్రమాన్ని ఉపయోగిస్తున్నారు:
Gallery.js:Profileకంపోనెంట్ను నేమ్డ్ ఎక్స్పోర్ట్ చేస్తుంది, దీనినిProfileఅని పిలవబడుతుంది.Galleryకంపోనెంట్ను డిఫాల్ట్ ఎక్స్పోర్ట్ గా ఎక్స్పోర్ట్ చేస్తుంది.
App.js:Gallery.jsనుండిProfileను నేమ్డ్ ఇంపోర్ట్ చేసుకుంటుంది, దీనినిProfileఅని పిలవబడుతుంది.GalleryనుGallery.jsనుండి డిఫాల్ట్ ఇంపోర్ట్ గా ఇంపోర్ట్ చేసుకుంటుంది.- రూట్
Appకంపోనెంట్ను డిఫాల్ట్ ఎక్స్పోర్ట్ గా ఎక్స్పోర్ట్ చేస్తుంది.
Recap
ఈ పేజీలో మీరు నేర్చుకున్నవి::
- రూట్ కంపోనెంట్ ఫైల్ అంటే ఏమిటి
- ఒక కంపోనెంట్ను ఎలా ఇంపోర్ట్ మరియు ఎక్స్పోర్ట్ చేయాలి
- డిఫాల్ట్ మరియు నేమ్డ్ ఇంపోర్ట్స్ మరియు ఎక్స్పోర్ట్స్ ను ఎప్పుడు మరియు ఎలా ఉపయోగించాలి
- ఒకే ఫైల్ నుండి అనేక కంపోనెంట్లను ఎలా ఎక్స్పోర్ట్ చేయాలి
Challenge 1 of 1: కంపోనెంట్లను మరింత విభజించండి
ప్రస్తుతం, Gallery.js రెండు Profile మరియు Gallery కంపోనెంట్లను ఎక్స్పోర్ట్ చేస్తుంది, ఇది కొంత గందరగోళంగా ఉంది.
Profile కంపోనెంట్ను దాని స్వంత Profile.js కు తరలించండి, మరియు తర్వాత App కంపోనెంట్ను మార్చి <Profile /> మరియు <Gallery /> ను వరుసగా రెండర్ చేయండి.
మీరు Profile కోసం డిఫాల్ట్ లేదా నేమ్డ్ ఎక్స్పోర్ట్ను ఉపయోగించవచ్చు, కానీ మీరు రెండు App.js మరియు Gallery.js లో సరైన ఇంపోర్ట్ సింట్యాక్స్ను ఉపయోగిస్తున్నారో చూడండి! మీరు పై డీప్ డైవ్ లోని చార్టును చూడవచ్చు:
| సింటాక్స్ | ఎక్స్పోర్ట్ స్టేట్మెంట్ | ఇంపోర్ట్ స్టేట్మెంట్ |
|---|---|---|
| డిఫాల్ట్ | export default function Button() {} | import Button from './Button.js'; |
| నేమ్డ్ | export function Button() {} | import { Button } from './Button.js'; |
// Move me to Profile.js! export function Profile() { return ( <img src="https://i.imgur.com/QIrZWGIs.jpg" alt="Alan L. Hart" /> ); } export default function Gallery() { return ( <section> <h1>Amazing scientists</h1> <Profile /> <Profile /> <Profile /> </section> ); }
మీరు ఒక రకమైన ఎక్స్పోర్ట్లతో అది పని చేసేలా చేసిన తరువాత, మరొక రకంతో కూడా పని చేసేలా ప్రయత్నించండి.