కంపోనెంట్లను ఇంపోర్ట్ మరియు ఎక్స్పోర్ట్ చేయడం
కంపోనెంట్ల మ్యాజిక్ వాటి రీయూజబులిటీలో ఉంది: మీరు ఇతర కంపోనెంట్లతో కలిపిన కంపోనెంట్లను సృష్టించవచ్చు. కానీ మీరు మరింత ఎక్కువ కంపోనెంట్లను నెస్ట్ చేస్తూ ఉండగా, వాటిని వేర్వేరు ఫైళ్లలో విభజించడం అనేది సాధారణంగా సరియిన నిర్ణయం అవుతుంది. ఇది మీ ఫైళ్లను సులభంగా స్కాన్ చేయగలిగేలా చేస్తుంది మరియు కంపోనెంట్లను మరిన్ని ప్రదేశాలలో రీయూజబుల్ చేసుకునేందుకు అనుకూలంగా ఉంటుంది.
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> ); }
మీరు ఒక రకమైన ఎక్స్పోర్ట్లతో అది పని చేసేలా చేసిన తరువాత, మరొక రకంతో కూడా పని చేసేలా ప్రయత్నించండి.