journey
title మీ బ్యాంకింగ్ యాప్ అభివృద్ధి ప్రయాణం
section SPA ప్రాథమికాలు
సింగిల్-పేజీ యాప్స్ ని అర్థం చేసుకోండి: 3: Student
టెంప్లేట్ ধারণాలను నేర్చుకోండి: 4: Student
DOM మానిప్యులేషన్ లో నైపుణ్యం సాధించండి: 4: Student
section రౌటింగ్ వ్యవస్థలు
క్లయింట్-సైడ్ రౌటింగ్ ని అమలు చేయండి: 4: Student
బ్రౌజర్ చరిత్రను నిర్వహించండి: 5: Student
నావిగేషన్ వ్యవస్థలను సృష్టించండి: 5: Student
section వృత్తిపరమైన నమూనాలు
మాడ్యులర్ ఆర్కిటెక్చర్ ని నిర్మించండి: 5: Student
ఉత్తమ ఆచారాలను వర్తించండి: 5: Student
యూజర్ అనుభవాలను సృష్టించండి: 5: Student
1969లో అపోలో 11 యొక్క గైడెన్స్ కంప్యూటర్ చంద్రుడి వైపు నావిగేట్ అయినప్పుడు, అది మొత్తం సిస్టమ్ను రీస్టార్ట్ చేయకుండా వివిధ ప్రోగ్రామ్ల మధ్య మార్పులు చేయాల్సి వచ్చింది. ఆధునిక వెబ్ అప్లికేషన్లు కూడా సమానంగా పనిచేస్తాయి – అవి మీరు చూసే విషయాన్ని పూర్తిగా రీలోడ్ చేయకుండా మార్చుతాయి. ఇది నేడు వినియోగదారులు ఆశించే సున్నితమైన, స్పందనक्षम అనుభవాన్ని సృష్టిస్తుంది.
ప్రస్తుత కాలపు వెబ్ యాప్లు ప్రతి ఇంటరాక్షన్కు పూర్తయిన పేజీలను రీలోడ్ చేయకుండా, మార్పు అవసరమైన భాగాలనే నవీకరిస్తాయి. ఇది మిషన్ కంట్రోల్ వివిధ డిస్ప్లేలను మారుస్తూ నిరంతర సంభాషణను కొనసాగించే విధానంలా, ఆ సున్నితమైన అనుభవాన్ని సృష్టిస్తుంది.
క్రింద ఉన్నది విపరీతమైన తేడాను సృష్టించే అంశాలు:
| సాంప్రదాయ బహుపేజీ యాప్లు | ఆధునిక ఏకపేజీ యాప్లు |
|---|---|
| నావిగేషన్ | ప్రతి స్క్రీన్ కోసం పూర్తి పేజీ రీలోడ్ |
| ప్రదర్శన | పూర్తి HTML డౌన్లోడ్స్ కారణంగా మందగింపు |
| వినియోగదారు అనుభవం | అనూహ్యంగా పేజీ చిమ్ములు |
| డేటా భాగస్వామ్యం | పేజీల మధ్య కఠినమైనది |
| వికాసం | బహుళ HTML ఫైళ్ళు నిర్వహణకు |
వికాసాన్ని అర్థం చేసుకోండి:
- సాంప్రదాయ యాప్లు ప్రతి నావిగేషన్ చర్యకు సర్వర్ అభ్యర్థనలు అవసరం
- ఆధునిక SPAలు ఒకసారి లోడ్ చేసి, జావాస్క్రిప్ట్ ఉపయోగించి డైనమిక్ కంటెంట్ నవీకరణ
- వినియోగదారుల ఆశలలో తక్షణ, సజల ఇంటరాక్షన్లు ప్రాధాన్యం
- ప్రదర్శన లాభాలు సమస్తమైన బ్యాండ్విడ్త్ తగ్గింపు మరియు వేగవంతమైన స్పందనలు
ఈ పాఠంలో, అనేక స్క్రీన్లు సజావుగా కలిసిన బ్యాంకింగ్ యాప్ని నిర్మించబోతున్నాం. శాస్త్రవేత్తలు వివిధ ప్రయోగాలకు మాడ్యూలర్ సర్దుబాటు సాధనాలు ఉపయోగించే విధంగా, మనం HTML టెంప్లేట్లను మళ్లీ ఉపయోగించదగిన భాగాలుగా ఉపయోగించి అవసరమైనప్పుడు ప్రదర్శిస్తాం.
మీరు HTML టెంప్లేట్లతో (విభిన్న స్క్రీన్ల కోసం మళ్లీ ఉపయోగించదగిన ప్రణాళికలు), జావాస్క్రిప్ట్ రౌటింగ్ (స్క్రీన్ల మధ్య మార్పిదించే వ్యవస్థ), మరియు బ్రౌజర్ యొక్క హిస్టరీ API (బ్యాక్ బటన్ సరిగ్గా పనిచేయడానికి) తో పని చేస్తారు. ఇవే React, Vue, మరియు Angular వంటి ఫ్రేమ్వర్క్లలో ఉపయోగించే ప్రాథమిక సాంకేతికతలు.
చివరికి, మీరు ఒక ప్రొఫెషనల్ ఏకపేజీ అప్లికేషన్ ప్రిన్సిపల్స్ను చూపించే పనిచేసే బ్యాంకింగ్ యాప్ను పొందుతారు.
mindmap
root((సింగిల్-పేజీ అప్లికేషన్లు))
Architecture
Template System
Client-side Routing
State Management
Event Handling
Templates
Reusable Components
Dynamic Content
DOM Manipulation
Content Switching
Routing
URL Management
History API
Navigation Logic
Browser Integration
User Experience
వేగవంతమైన నావిగేషన్
స్మూత్ ట్రాన్సిషన్లు
సాదృశ్య స్థితి
ఆధునిక ఇంటరాక్షన్లు
Performance
తగ్గించిన సర్వర్ అభ్యర్థనలు
వేగవంతమైన పేజీ మార్పులు
సమర్థవంతమైన వనరు ఉపయోగం
మెరుగైన స్పందనశీలత
మన బ్యాంకింగ్ యాప్ను పరీక్షించడానికి స్థానిక వెబ్ సర్వర్ కావాలి – ఇది మీ ఊహించినంత కష్టం కాదు! మీరు ఇప్పటికే సెట్ చేయకపోతే, కేవలం Node.jsని ఇనిస్టాల్ చేసి npx lite-server ను మీ ప్రాజెక్ట్ ఫోల్డర్ నుండి రన్ చేయండి. ఇది స్థానిక సర్వర్ను స్పిన్ చేస్తుంది మరియు ఆటోమేటిగ్గా బ్రౌజర్లో మీ యాప్ను ఓపెన్ చేస్తుంది.
మీ కంప్యూటర్లో bank అనే ఫోల్డర్ని సృష్టించి, అందులో index.html అనే ఫైల్ని ఉంచండి. మనం ఈ HTML బాయిలర్ప్లేట్ నుండి మొదలుపెడతాం:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Bank App</title>
</head>
<body>
<!-- This is where you'll work -->
</body>
</html>ఈ బాయిలర్ప్లేట్ అందించే అంశాలు:
- HTML5 డాక్యుమెంట్ నిర్మాణాన్ని సరైన DOCTYPE ప్రకటనతో స్థాపిస్తుంది
- అంతర్జాతీయ పాఠ్య మద్దతుకు UTF-8 క్యారెక్టర్ ఎంకోడింగ్ను అమర్చుతుంది
- పోర్టబుల్ కనుగొనికకు viewport మెటా ట్యాగ్ తో స్పందనకరమైన డిజైన్ను ఏర్పాటు చేస్తుంది
- బ్రౌజర్ టాబ్లో కనిపించే వివరాత్మక శీర్షికను సెట్ చేస్తుంది
- మనం అంజలి చేయబోయే అప్లికేషన్ కోసం శుభ్రమైన బాడీ సెక్షన్ను సృష్టిస్తుంది
📁 ప్రాజెక్ట్ నిర్మాణం అవలోకనం
ఈ పాఠం ముగిసే వరకు, మీ ప్రాజెక్ట్లో ఈ ఫైళ్లు ఉంటాయి:
bank/ ├── index.html <!-- Main HTML with templates --> ├── app.js <!-- Routing and navigation logic --> └── style.css <!-- (Optional for future lessons) -->ఫైల్ బాధ్యతలు:
- index.html: అన్ని టెంప్లేట్లను కలిగి ఉండి యాప్ నిర్మాణాన్ని అందిస్తుంది
- app.js: రౌటింగ్, నావిగేషన్, మరియు టెంప్లేట్ల నిర్వహణను చేపడుతుంది
- టెంప్లేట్లు: లాగిన్, డాష్బోర్డ్ మరియు ఇతర స్క్రీన్ల UIని నిర్వచిస్తాయి
టెంప్లేట్లు వెబ్ డెవలప్మెంట్లో ఒక ప్రాథమిక సమస్యను పరిష్కరిస్తాయి. గుటెన్బర్గ్ 1440లలో మొవబుల్ టైప్ ప్రింటింగ్ను ఆవిష్కరించినప్పుడు, పూర్తి పేజీలను చెక్కేసే బదులు ఉపయోగించదగిన లెటర్ బ్లాక్స్ను తయారు చేసి వాటిని అవసరమనుకుని అమరిక చేయొచ్చని తెలుసుకున్నాడు. HTML టెంప్లేట్లు అదే సిద్ధాంతంపై పనిచేస్తాయి – ప్రతి స్క్రీన్ కోసం వేర్వేరు HTML ఫైల్లు సృష్టించకుండా, అవసరానికి తగిన reusable నిర్మాణాలను నిర్వచిస్తారు.
flowchart TD
A["📋 టెంప్లేట్ నిర్వచనం"] --> B["💬 DOMలో దాచబడింది"]
B --> C["🔍 జావాస్క్రిప్ట్ టెంప్లేట్ పొందదు"]
C --> D["📋 టెంప్లేట్ కంటెంట్ని క్లోన్ చేయండి"]
D --> E["🔗 దృశ్యమానమైన DOMకి జత చేయండి"]
E --> F["👁️ వినియోగదారు కంటెంట్ని చూస్తున్నాడు"]
G["లాగిన్ టెంప్లేట్"] --> A
H["డాష్బోర్డ్ టెంప్లేట్"] --> A
I["భవిష్యత్ టెంప్లేట్లు"] --> A
style A fill:#e3f2fd
style D fill:#e8f5e8
style F fill:#fff3e0
style B fill:#f3e5f5
మీ యాప్ అనేక భాగాలకు టెంప్లేట్లను బ్లూ ప్రింట్లాగా ఆలోచించండి. ఒక ఆర్కిటెక్ట్ ఒక బ్లూ ప్రింట్ సృష్టించి అటు ఇటు పునరావృతంగా ఉపయోగిస్తే, మేము టెంప్లేట్లను ఒకసారి సృష్టించి అవసరానికి అనుగుణంగా ఉపయోగిస్తాం. బ్రౌజర్ ఈ టెంప్లేట్లను దాచివుంచి, జావాస్క్రిప్ట్ వాటిని యాక్టివేట్ చేసే వరకు చూపించదు.
మీరు ఒక వెబ్ పేజీకి అనేక స్క్రీన్లు సృష్టించదలిచినట్లయితే, ఒక పరిష్కారం ప్రతి స్క్రీన్ కోసం ఒక HTML ఫైల్ సృష్టించడం. అయినప్పటికీ, ఈ పరిష్కారానికి కొన్ని అసౌకర్యాలు ఉన్నాయి:
- స్క్రీన్ మార్చేటప్పుడు మొత్తం HTMLని రీలోడ్ చేయాల్సి ఉంటుంది, ఇది మందగింపును కలిగిస్తుంది.
- వివిధ స్క్రీన్ల మధ్య డేటా పంచుకోవడం కష్టమే.
మరొక విధానం ఒకే HTML ఫైల్ ఉండటం మరియు <template> ఎలిమెంట్ ఉపయోగించి బహుళ HTML టెంప్లేట్లు నిర్వచించడం. టెంప్లేట్ అనేది బ్రౌజర్ ద్వారా ప్రదర్శించని, జావాస్క్రిప్ట్ ద్వారా রান్టైంలో instantiate చెయ్యవలసిన మళ్లీ ఉపయోగించదగిన HTML బ్లాక్.
మనకు బ్యాంక్ యాప్ కోసం రెండు ప్రధాన స్క్రీన్లు ఉంటాయి: లాగిన్ పేజీ మరియు డాష్బోర్డ్. మొదట, మనం HTML బాడీలో ఒక ప్లేస్హోల్డర్ ఎలిమెంట్ను చేర్చుదాం – ఇక్కడ మన అంతా విభిన్న స్క్రీన్లు కనిపిస్తాయి:
<div id="app">Loading...</div>ఈ ప్లేస్హోల్డర్ అర్థం:
- అన్ని స్క్రీన్లు ప్రదర్శించబడే "app" ఐడీతో కంటైనర్ సృష్టిస్తుంది
- జావాస్క్రిప్ట్ మొదటి స్క్రీన్ యాక్టివేట్ అయ్యేవరకు లోడ్ అవుతున్న సందేశాన్ని చూపిస్తుంది
- మన డైనమిక్ కంటెంట్ కోసం ఒక్క మౌంటింగ్ పాయింట్ అందిస్తుంది
document.getElementById()ద్వారా సులభంగా లక్ష్యం చేయబడుతుంది
💡 ప్రొ టిప్: ఈ ఎలిమెంట్ యొక్క కంటెంట్ మార్చబడే కాబట్టి, యాప్ లోడ్ అవుతున్నప్పుడు చూపించే లోడింగ్ సందేశం లేదా సూచికను ఇక్కడ ఉంచవచ్చు.
తర్వాత, HTML టెంప్లేట్ క్రింద లాగిన్ పేజీ కోసం చేర్చుదాం. ఇప్పటికీ ఇక్కడ కేవలం శీర్షిక మరియు నావిగేషన్ కోసం లింక్ ఉన్న సెక్షన్ ఉంచుతాం.
<template id="login">
<h1>Bank App</h1>
<section>
<a href="/dashboard">Login</a>
</section>
</template>ఈ లాగిన్ టెంప్లేట్ విశ్లేషణ:
- జావాస్క్రిప్ట్ లక్ష్యంగా "login" అనే ప్రత్యేక గుర్తింపుతో టెంప్లేట్ నిర్వచిస్తుంది
- అప్లికేషన్ బ్రాండింగ్ గుర్తించడానికి ప్రధాన శీర్షికను కలిగి ఉంది
- సంబంధిత కంటెంట్ను సమూహీకరించడానికి సెమాంటిక్
<section>ఉపయోగిస్తుంది - వినియోగదారులను డాష్బోర్డ్కి నావిగేట్ చేసే లింక్ను అందిస్తుంది
తర్వాత, డాష్బోర్డ్ పేజీకి మరో HTML టెంప్లేట్ చేర్చుదాం. ఈ పేజీ వివిధ సెక్షన్లు కలిగి ఉంటుంది:
- శీర్షికలో ఒక శీర్షిక మరియు లాగ్ ఔట్ లింక్
- బ్యాంక్ ఖాతా ప్రస్తుత బ్యాలెన్స్
- లావాదేవీల జాబితా, టేబుల్ రూపంలో ప్రదర్శించబడుతుంది
<template id="dashboard">
<header>
<h1>Bank App</h1>
<a href="/login">Logout</a>
</header>
<section>
Balance: 100$
</section>
<section>
<h2>Transactions</h2>
<table>
<thead>
<tr>
<th>Date</th>
<th>Object</th>
<th>Amount</th>
</tr>
</thead>
<tbody></tbody>
</table>
</section>
</template>ఈ డాష్బోర్డ్ యొక్క భాగాల విశ్లేషణ:
- నావిగేషన్ కలిగిన సెమాంటిక్
<header>ఉపయోగించి పేజీ నిర్మాణం - స్క్రీన్లలో యాప్ శీర్షికను స్థిరంగా ప్రదర్శిస్తుంది
- లాగ్ ఔట్ లింక్, ఇది లాగిన్ స్క్రీన్కు తిరిగి నావిగేట్ చేస్తుంది
- ప్రత్యేక సెక్షన్లో ప్రస్తుత అకౌంట్ బ్యాలెన్స్ చూపిస్తుంది
- సరైన HTML టేబుల్ ఉపయోగించి లావాదేవీల డేటాను ఏర్పాటు చేస్తుంది
- తేదీ, ఆబ్జెక్ట్, మరియు రుసుముల కోసం వడపోత టేబుల్ హెడ్డర్లను నిర్వచిస్తుంది
- డైనమిక్ కంటెంట్ ఇంజెక్షన్ కోసం టేబుల్ శరీర భాగాన్ని ఖాళీగా ఉంచుతుంది
💡 ప్రొ టిప్: HTML టెంప్లేట్లు సృష్టిస్తుంటే, మీరు వాటి ఎలాగుని చూడాలని ఉంటే,
<template>మరియు</template>లైన్లను<!-- -->లో ప్యాక్ చేసి కామెంట్ అవ్వవచ్చు.
టెంప్లేట్ వ్యవస్థ అర్థం చేసుకోండి: జావాస్క్రిప్ట్ అమలు చేసేముందు కలిగాలి:
- ✅ టెంప్లేట్లు సాధారణ HTML ఎలిమెంట్లతో ఎలా వేరుగా ఉంటాయో
- ✅ టెంప్లేట్లు జావాస్క్రిప్ట్ యాక్టివేషన్ వరకు దాచివున్నాయి ఎందుకు
- ✅ టెంప్లేట్లలో సెమాంటిక్ HTML నిర్మాణం ప్రాముఖ్యం
- ✅ టెంప్లేట్లు మళ్లీ ఉపయోగించదగిన UI భాగాలు ఎలా సృష్టిస్తాయి
తీవ్ర స్వీయ-పరీక్ష: మీ HTML చుట్టూ <template> ట్యాగ్స్ తీసేసినప్పుడు ఏం జరుగుతుంది?
సమాధానం: కంటెంట్ తక్షణమే కనిపిస్తుంది మరియు దానికి టెంప్లేట్ ఫంక్షనాలిటీ ఉంటది కాదు
పనితనం లాభాలు: టెంప్లేట్లు అందించేవి:
- మళ్లీ ఉపయోగ్యత: ఒక నిర్వచనం, బహుళ ఘటనలు
- ప్రదర్శన: డూప్లికేట్ HTML పార్సింగ్ చేయబడదు
- నిర్వాహకత: కేంద్రీకృత UI నిర్మాణం
- అనువర్తనం: డైనమిక్ కంటెంట్ మార్పులు
✅ మనం టెంప్లేట్లపై id లక్షణాలు ఎందుకు ఉపయోగిస్తాం? వేరే ఏదైనా తరగతులు లాగా ఉపయోగించవచ్చా?
ఇప్పుడు మన టెంప్లేట్లను కార్యాచరణ చేయాలి. 3D ప్రింటర్ డిజిటల్ బ్లూప్రింట్ని తీసుకుని భౌతిక వస్తువుగా మార్చినట్లే, జావాస్క్రిప్ట్ మన దాచిపెట్టిన టెంప్లేట్లను ఆవిష్కరిస్తుంది, వినియోగదారులు వీటిని చూడగలిగే, పరస్పర చర్యల సాధనంగా మార్చుతుంది.
ఈ ప్రక్రియ మూడు స్థిరమైన దశల్లో జరుగుతుంది, ఇవి ఆధునిక వెబ్ డెవలప్మెంట్ స్థంభాలు. మీరు ఈ నమూనా అర్థం చేసుకున్నా తరువాత, మీరు దీన్ని అనేక ఫ్రేమ్వర్క్లు మరియు లైబ్రరీలలో గుర్తిస్తారు.
మీ ప్రస్తుత HTML ఫైల్ను బ్రౌజర్లో ప్రయత్నిస్తే, అది Loading... చూపిస్తూ నిలిచిపోతుంది. ఎందుకంటే మనం టెంప్లేట్లను instantiate చేసి ప్రదర్శించేందుకు కొన్ని జావాస్క్రిప్ట్ కోడును జత చేయాలి.
ఒక టెంప్లేట్ instantiate చెయ్యడం సాధారణంగా 3 దశల్లో జరుగుతుంది:
- DOMలో టెంప్లేట్ ఎలిమెంట్ను పొందడం, ఉదాహరణకు
document.getElementByIdఉపయోగించి. - టెంప్లేట్ ఎలిమెంట్ను క్లోన్ చేసుకోవడం,
cloneNodeఉపయోగించి. - దాన్ని DOMలో కనిపించే ఎలిమెంట్ కింద జత చేయడం, ఉదాహరణకు
appendChildఉపయోగించి.
flowchart TD
A[🔍 దశ 1: టెంప్లేట్ కనుగొనండి] --> B[📋 దశ 2: టెంప్లేట్ క్లోన్ చేయండి]
B --> C[🔗 దశ 3: DOM కి সংযুক্ত చేయండి]
A1["document.getElementById('login')"] --> A
B1["template.content.cloneNode(true)"] --> B
C1["app.appendChild(view)"] --> C
C --> D[👁️ టెంప్లేట్ వాడుకరికి కనపడుతుంది]
style A fill:#e1f5fe
style B fill:#f3e5f5
style C fill:#e8f5e8
style D fill:#fff3e0
ఈ ప్రక్రియ దృశ్య వివరణ:
- దశ 1 దాచిన టెంప్లేట్ను DOM నిర్మాణంలో వెతుకుతుంది
- దశ 2 సురక్షితంగా మార్పులు చేయదగిన పని కాపీని సృష్టిస్తుంది
- దశ 3 కాపీని కనిపించే పేజీ ప్రాంతంలో చేర్చుతుంది
- ఫలితం ఉపయోగకర్తలు పరస్పర చర్యలు చేయగలిగే ప్రాచుర్యమైన స్క్రీన్
✅ మనం టెంప్లేట్ ను DOMకి జత చేసే ముందు క్లోన్ చెయ్యాలంటే ఎందుకు? ఈ దశను తప్పిస్తే ఏం జరుగుతుందంటారు?
మీ ప్రాజెక్ట్ ఫోల్డర్లో app.js అనే కొత్త ఫైల్ సృష్టించి, దాన్ని మీ HTML <head> సెక్షన్లో దిగుమతి చేసుకోండి:
<script src="app.js" defer></script>ఈ స్క్రిప్ట్ దిగుమతి అర్థం:
- జావాస్క్రిప్ట్ ఫైల్ను మన HTML డాక్యుమెంట్తో లింక్ చేస్తుంది
deferలక్షణం ఉపయోగించి స్క్రిప్ట్ HTML పార్సింగ్ పూర్తైన తర్వాత నడుస్తుంది- DOM ఎలిమెంట్లకు యాక్సెస్ స్క్రిప్ట్ ఎగ్జిక్యూషన్ ముందే అందుబాటులో ఉంటుందని నిర్ధారిస్తుంది
- స్క్రిప్ట్ లోడింగ్ మరియు ప్రదర్శనకు ఆధునిక ఉత్తమ పద్ధతులను అనుసరిస్తుంది
ఇప్పుడు app.js లో కొత్త ఫంక్షన్ updateRoute సృష్టిద్దాం:
function updateRoute(templateId) {
const template = document.getElementById(templateId);
const view = template.content.cloneNode(true);
const app = document.getElementById('app');
app.innerHTML = '';
app.appendChild(view);
}దశా దశా వివరణ:
- ప్రత్యేక ID ఉపయోగించి టెంప్లేట్ ఎలిమెంట్ను కనుగొంటుంది
cloneNode(true)ఉపయోగించి టెంప్లేట్ కంటెంట్ గాఢ కాపీని సృష్టిస్తుంది- కంటెంట్ ప్రదర్శించబడే యాప్ కంటైనర్ను వెతుకుతుంది
- యాప్ కంటైనర్ నుండి ఉన్న కంటెంట్ ను మాయం చేస్తుంది
- క్లోన్ చేసిన టెంప్లేట్ కంటెంట్ను కనిపించే DOMలో చేర్పిస్తుంది
ఇప్పుడు ఈ ఫంక్షన్ను ఒక టెంప్లేట్ IDతో పిలవండి మరియు ఫలితాన్ని చూడండి.
updateRoute('login');ఈ ఫంక్షన్ కాల్ ఆధిగమనాలు:
- తన యొక్క IDని పారామీటర్గా పంపడం ద్వారా లాగిన్ టెంప్లేట్ యాక్టివేట్ అవుతుంది
- వేర్వేరు యాప్ స్క్రీన్ల మధ్య ప్రోగ్రామాటిక్ మార్పును చూపిస్తుంది
- "Loading..." సందేశం బదులుగా లాగిన్ స్క్రీన్ చూపిస్తుంది
✅ ఈ కోడ్ app.innerHTML = ''; ఉద్దేశ్యం ఏమిటి? దీని లేకుండా ఏం జరుగుతుంది?
రౌటింగ్ అనేది URLs ను సరైన కంటెంట్కు కనెక్ట్ చేయడం. తొలుత టెలిఫోన్ ఆపరేటర్లు కాల్లను కనెక్ట్ చేయడానికి స్విచ్బోర్డ్స్ ఉపయోగించిన విధంగా, వారు వచ్చే అభ్యర్థనను సరైన గమ్యస్థానానికి నావిగేట్ చేసిన విధంగా, వెబ్ రౌటింగ్ కూడా URL అభ్యర్థన తీసుకుని ఏ కంటెంట్ చూపించాలో నిర్ణయిస్తుంది.
flowchart LR
A["🌐 URL మార్గం<br/>/dashboard"] --> B["🗺️ మార్గాలు వస్తువు<br/>లుకప్"]
B --> C["🎯 టెంప్లేట్ ID<br/>'dashboard'"]
C --> D["📌 టెంప్లేట్ కనుగొనండి<br/>getElementById"]
D --> E["👁️ స్క్రీన్ ప్రదర్శన<br/>నకలు & జోడించు"]
F["📍 /login"] --> G["🎯 'login'"]
H["📍 /unknown"] --> I["❌ కనుగొనలేదు"]
I --> J["🔄 /login కి రీడైరెక్ట్ చేయండి"]
style B fill:#e3f2fd
style E fill:#e8f5e8
style I fill:#ffebee
style J fill:#fff3e0
సాంప్రదాయంగా వెబ్ సర్వర్లు వివిధ URLలకు విభిన్న HTML ఫైళ్ళను అందిస్తూ దీన్ని నిర్వహించేవి. మనం ఏకపేజీ యాప్ నిర్మించే కనుక, రౌటింగ్ని మనమే జావాస్క్రిప్ట్తో నిర్వహించాల్సి ఉంటుంది. ఇది వినియోగదారుడి అనుభవం మరియు ప్రదర్శనపై మనకు మరింత నియంత్రణ ఇస్తుంది.
flowchart LR
A["🌐 URL మార్గం<br/>/డాష్బోర్డ్"] --> B["🗺️ మార్గాలు ఆబ్జెక్ట్<br/>శోధన"]
B --> C["🎯 టెంప్లేట్ ID<br/>'డాష్బోర్డ్'"]
C --> D["📄 టెంప్లేట్ను కనుగొను<br/>getElementById"]
D --> E["👁️ స్క్రీన్ను ప్రదర్శించు<br/>నకిలీ & జోడించు"]
F["📍 /లాగిన్"] --> G["🎯 'లాగిన్'"]
H["📍 /అజ్ఞాత"] --> I["❌ కనబడలేదు"]
I --> J["🔄 /లాగిన్ కు పునఃనిర్దేశించు"]
style B fill:#e3f2fd
style E fill:#e8f5e8
style I fill:#ffebee
style J fill:#fff3e0
రౌటింగ్ నిర్వహణ ప్రవాహం:
- URL మార్పులు మన రూట్ల కాన్ఫిగరేషన్ లోకి వెతుకుతున్నాయి
- చెల్లును రూట్లు నిర్దిష్ట టెంప్లేట్ IDలకు మ్యాపింగ్ చేస్తాయి
- చెల్లని రూట్లు సరికొత్త స్థితులు రాకుండా బ్యాకప్ చర్యలు తీసుకుంటూ ఉంటాయి
- టెంప్లేట్ ప్రదర్శన మనం ముందుగా నేర్చుకున్న మూడు దశల ప్రక్రియని అనుసరిస్తుంది
వెబ్ యాప్ గురించి చెప్పేటప్పుడు, మనం URLs ని ప్రదర్శించవలసిన స్క్రీన్లతో మ్యాప్ చేయాలనే ఉద్దేశాన్ని Routing అంటాము. బహుళ HTML ఫైళ్ళు ఉన్న వెబ్సైట్ల సమస్య కాదు, ఎందుకంటే ఫైల్ పాథ్లు URLలో ప్రతిబింబిస్తాయి.
ఉదాహరణకు, మీ ప్రాజెక్ట్ ఫోల్డర్లో ఈ ఫైళ్ళు ఉంటే:
mywebsite/index.html
mywebsite/login.html
mywebsite/admin/index.html
mywebsite అనే రూట్తో వెబ్ సర్వర్ సృష్టిస్తే, URL మ్యాపింగ్ ఇలా ఉంటుంది:
https://site.com --> mywebsite/index.html
https://site.com/login.html --> mywebsite/login.html
https://site.com/admin/ --> mywebsite/admin/index.html
కానీ మన వెబ్ యాప్కు అన్ని స్క్రీన్లను కలిగి ఉన్న ఏక HTML ఫైల్ ఉన్నందున, ఈ డిఫాల్ట్ ప్రవర్తన మనకు ఉపయోగపడదు. మనం ఈ మ్యాప్ను చేతితో సృష్టించి జావాస్క్రిప్ట్ ఉపయోగించి ప్రదర్శించబడే టెంప్లేట్ను అప్డేట్ చేయాల్సి ఉంటుంది.
URL మార్గాలను మన టెంప్లేట్లతో మ్యాపింగ్ చేయడానికి సరళమైన ఆబ్జెక్ట్ ఉపయోగిస్తాం. దీన్ని app.js ఫైల్ టాప్లో చేర్చండి.
const routes = {
'/login': { templateId: 'login' },
'/dashboard': { templateId: 'dashboard' },
};ఈ రూట్స్ కాన్ఫిగరేషన్ అర్థం:
- URL పాథ్లు మరియు టెంప్లేట్ గుర్తింపుల మధ్య మ్యాపింగ్ నిర్వచిస్తుంది
- కీస్ URL మార్గాలుగా ఉండి, విలువలు టెంప్లేట్ సమాచారం కలిగి ఉండతాయి
- ఏ URLకి ఏ టెంప్లేట్ చూపించాలో సులభంగా వెతుక్కోవడానికి సహకరిస్తుంది
- భవిష్యత్లో కొత్త రూట్లను జోడించడానికి కంపత్\u200cఎస్\u200cరకం నిర్మాణాన్ని అందిస్తుంది
ఇప్పుడు మనము
updateRouteఫంక్షన్ను కొంచెం మారుస్తాము. నేరుగాtemplateIdని ఆర్గ్యుమెంటుగా పంపించకుండా, మనము మొదట ప్రస్తుత URLను చూస్తాము మరియు ఆ తర్వాత మన మ్యాప్ ద్వారా తగిన template ID విలువను పొందుతాము. URL లోని పాత్ సెక్షన్ మాత్రమే పొందటానికి మనముwindow.location.pathnameఉపయోగించవచ్చు.
function updateRoute() {
const path = window.location.pathname;
const route = routes[path];
const template = document.getElementById(route.templateId);
const view = template.content.cloneNode(true);
const app = document.getElementById('app');
app.innerHTML = '';
app.appendChild(view);
}ఇక్కడ జరిగేది విడదీసి చూసితే:
- ప్రస్తుతం ఉన్న పాత్ను బ్రౌజర్ యొక్క URL నుండి
window.location.pathnameఉపయోగించి తీసుకుంటుంది - మన routes ఆబ్జెక్టులోని తగిన route కాన్ఫిగరేషన్ను తీసుకుని చూస్తుంది
- ఆ route కాన్ఫిగరేషన్ నుండి template ID ని పొందుతుంది
- ముందు ఉన్నట్లే templateని రెండర్ చేయడం చేస్తుంది
- URL మార్పులకు స్పందించే ఒక డైనమిక్ సిస్టమ్ను సృష్టిస్తుంది
ఇక్కడ మనం ప్రకటించిన routes ని సంబంధిత template తో మ్యాప్ చేసాము. మీరు మీ బ్రౌజర్ లో URLని మాన్యువల్గా మార్చి అది సరిగా పనిచేస్తుందా అని పరీక్షించవచ్చు.
✅ మీరు URLలో తెలియని పాత్ ఎంటర్ చేస్తే ఏమ అవుతుంది? మనం దీన్ని ఎలా పరిష్కరించగలము?
రూటింగ్ ఏర్పాటు అయిన తరువాత, యూజర్లు యాప్ ద్వారా నావిగేట్ చేసేందుకు మార్గం కావాలి. సంప్రదాయ వెబ్సైట్లు లింకులు క్లిక్ చేస్తే మొత్తం పేజీలను రీలోడ్ చేస్తాయి, కానీ మనం URL మరియు కంటెంట్ రెండింటినీ పేజీ రీఫ్రెష్ లేకుండా అప్డేట్ చేయాలనుకుంటున్నాము. ఇది డెస్క్టాప్ అప్లికేషన్లు వివిధ వీక్షణల మధ్య ఎలా మారుతాయో అలా సాఫీగా అనుభవం కలిగిస్తుంది.
మనము రెండు విషయాలను సమన్వయపర్చాలి: యూజర్లు పేజీలను బుక్మార్క్ చేయగలిగేలా బ్రౌజర్ URLని అప్డేట్ చేయడం, మరియు సరైన కంటెంట్ని చూపించడం. ఇది సరిగా అమలు అయితే, ఆధునిక అప్లికేషన్ల నుండి యూజర్లు ఆశించే సాఫీ నావిగేషన్ ఉత్పత్తి అవుతుంది.
sequenceDiagram
participant User
participant Browser
participant App
participant Template
User->>Browser: "లాగిన్" లింక్ క్లిక్ చేసినాడు
Browser->>App: onclick సంఘటన ప్రారంభించబడింది
App->>App: preventDefault() & navigate('/dashboard')
App->>Browser: history.pushState('/dashboard')
Browser->>Browser: URL /dashboard కి నవీకరించబడింది
App->>App: updateRoute() పిలవబడింది
App->>Template: డ్యాష్బోర్డ్ టెంప్లేట్ వెతకు & క్లోన్ చెయ్
Template->>App: క్లోన్ చేయబడిన కంటెంట్ తిరిగివ్వండి
App->>Browser: టెంప్లేట్ తో యాప్ కంటెంట్ భర్తీ చేయండి
Browser->>User: డ్యాష్బోర్డ్ స్క్రీన్ చూపించు
Note over User,Template: వినియోగదారు బ్రౌజర్ వెనుకబటనును క్లిక్ చేస్తాడు
User->>Browser: వెనుక బటన్ క్లిక్ చేస్తున్నాడు
Browser->>Browser: చరిత్ర /login కి వెనక్కి పోయింది
Browser->>App: popstate సంఘటన ఆందితం అయింది
App->>App: updateRoute() ఆటోమేటిక్ పిలవబడింది
App->>Template: లాగిన్ టెంప్లేట్ వెతకు & క్లోన్ చెయ్
Template->>App: క్లోన్ చేయబడిన కంటెంట్ తిరిగివ్వండి
App->>Browser: టెంప్లేట్ తో యాప్ కంటెంట్ భర్తీ చేయండి
Browser->>User: లాగిన్ స్క్రీన్ చూపించు
సింగిల్-పేజీ అప్లికేషన్ ఆర్కిటెక్చర్: మీరు ఈ సమగ్ర వ్యవస్థపై అవగాహన కలిగారా?
- ✅ క్లయింట్-సైడ్ రూటింగ్ ఎలా సంప్రదాయ సర్వర్-సైడ్ రూటింగ్ నుండి వేరుగా ఉందో?
- ✅ సరిగ్గా SPA నావిగేషన్ కోసం హిస్టరీ API ఎందుకు అవసరం?
- ✅ టెంప్లేట్లు రీలోడ్లెల్లా డైనమిక్ కంటెంట్ను ఎలా అందిస్తాయి?
- ✅ నావిగేషన్ను ఇన్టెర్సెప్టు చేయడంలో ఈవెంట్ హ్యాండ్లింగ్ పాత్ర ఏమిటి?
సిస్టమ్ ఇంటిగ్రేషన్: మీ SPA ఈ అంశాలు చూపుతుంది:
- టెంప్లేట్ యాజమాన్యం: డైనమిక్ కంటెంట్తో తిరిగి ఉపయోగించే UI భాగాలు
- క్లయింట్-సైడ్ రూటింగ్: సర్వర్ అభ్యర్థన లేకుండా URL నిర్వహణ
- ఈవెంట్-ఆధారిత ఆర్కిటెక్చర్: స్పందించే నావిగేషన్ మరియు యూజర్ ఇంటరాక్షన్స్
- బ్రౌజర్ ఇంటిగ్రేషన్: సరైన హిస్టరీ మరియు బ్యాక్/ఫార్వర్డ్ బటన్ సపోర్ట్
- పర్ఫార్మెన్స్ ఆప్టిమైజేషన్: వేగవంతమైన మార్పులు మరియు సర్వర్ లోడ్ తగ్గింపు
ప్రొఫెషనల్ ప్యాటర్న్స్: మీరు ఇవి అమలు చేసారు:
- మోడల్-వ్యూకి విడదీయడం: అప్లికేషన్ లాజిక్ నుండి టెంప్లేట్లు వేరు చేయడం
- స్టేట్ మేనేజ్మెంట్: URL స్టేట్ మరియు ప్రదర్శిత కంటెంట్ సమన్వయం
- ప్రోగ్రెసివ్ ఎన్హాన్స్మెంట్: జావాస్క్రిప్ట్ సాధారణ HTML ఫంక్షనాలిటీని మెరుగుపరుస్తుంది
- యూజర్ అనుభవం: పేజీ రీఫ్రెష్ లేకుండా సాఫీ, యాప్లా నావిగేషన్
� ఆర్కిటెక్చర్ అవగాహన: నావిగేషన్ సిస్టమ్ భాగాలు
మీరు తయారు చేస్తున్నది:
- 🔄 URL నిర్వహణ: పేజీ రీలోడ్లేకుండా బ్రౌజర్ అడ్రస్ బార్ను అప్డేట్ చేస్తుంది
- 📋 టెంప్లేట్ సిస్టమ్: ప్రస్తుత రూటు ఆధారంగా కంటెంట్ దింపుతుంది
- 📚 హిస్టరీ ఇంటిగ్రేషన్: బ్రౌజర్ బ్యాక్/ఫార్వర్డ్ బటన్స్ పనిచేసేలా ఉంచుతుంది
- 🛡️ లోపాల నిర్వహణ: తప్పు లేదా లేని రూటులకు గౌరవనీయFallbacks
భాగాలు ఎలా కలిసి పనిచేస్తాయని:
- నావిగేషన్ ఈవెంట్లకు శ్రద్ధ వహిస్తుంది (క్లిక్లు, హిస్టరీ మార్పులు)
- హిస్టరీ API ఉపయోగించి URLను అప్డేట్ చేస్తుంది
- కొత్త రూటుకు సరైన టెంప్లెట్ను ప్రదర్శిస్తుంది
- సాఫీ యూజర్ అనుభవాన్ని నిరంతరం ఉంచుతుంది
మన యాప్ కోసం తదుపరి దశ URLను మాన్యువల్లీ మార్చకుండా పేజీలు మధ్య నావిగేట్ చేయగలగడం. దీన్ని చేయాలంటే రెండు పనులు:
- ప్రస్తుత URLని అప్డేట్ చేయడం
- ఒప్పిన URL ఆధారంగా ప్రదర్శిత టెంప్లెట్ను మార్చడం
రెండవ భాగాన్ని updateRoute ఫంక్షన్ తో పూర్తిచేశాము, కాబట్టి ఇప్పుడు ప్రస్తుత URL ని ఎలా అప్డేట్ చేయాలో చూద్దాం.
జావాస్క్రిప్ట్ మరియు ముఖ్యంగా history.pushState ఉపయోగించాలి, ఇది URLని అప్డేట్ చేసి బ్రౌజింగ్ హిస్టరీలో కొత్త ఎంట్రీ సృష్టిస్తుంది, HTMLని రీలోడ్ చేయకుండా.
⚠️ ముఖ్యమైన గమనిక: HTML యాంకర్ ఎలిమెంట్<a href>ని స్వతంత్రంగా వాడితే బ్రౌజర్ డిఫాల్ట్ గా HTMLని రీలోడ్ చేస్తుంది. కస్టమ్ జావాస్క్రిప్ట్ తో రూటింగ్ నిర్వహించేటప్పుడు ఈ ప్రవర్తననిpreventDefault()ఫంక్షన్ ద్వారా ఆపాలి.
మన యాప్లో నావిగేట్ చేయడానికి కొత్త ఫంక్షన్ సృష్టించుకుందాం:
function navigate(path) {
window.history.pushState({}, path, path);
updateRoute();
}ఈ నావిగేషన్ ఫంక్షన్ అవగాహన:
- బ్రౌజర్ URLని
history.pushStateఉపయోగించి కొత్త పాత్ కు అప్డేట్ చేస్తుంది - బ్రౌజర్ హిస్టరీ స్టాక్ లోకు కొత్త ఎంట్రీ జోడిస్తుంది తద్వారా బ్యాక్/ఫార్వర్డ్ బటన్లు సరిగ్గా పనిచేస్తాయి
- సరైన టెంప్లెట్ చూపించే
updateRoute()ఫంక్షన్ను ట్రిగ్గర్ చేస్తుంది - పేజీ రీలోడ్ లేకుండా ఒక సింగిల్-పేజీ యాప్ అనుభవాన్ని నిరంతరం ఉంచుతుంది
ఈ విధానం మొదట ఇచ్చిన పాత్ ఆధారంగా ప్రస్తుత URLను అప్డేట్ చేసి ఆ తర్వాత టెంప్లెట్ ను మారుస్తుంది. window.location.origin ప్రాపర్టీ URL మూలాన్ని ఇస్తుంది, దీని సహాయంతో ఒక పాత్ నుండి పూర్తి URLను తిరిగి నిర్మించవచ్చు.
ఇప్పుడు మనకు ఈ ఫంక్షన్ ఉందనుకొని, ఒక పాత్ ని ఎటువంటి డిఫైండ్ రూట్కు సరిపోనప్పుడు ఎలా వ్యవహరించాలో చూస్కోవాలి. మనం updateRoute ఫంక్షన్ను అప్డేట్ చేసి సరిపోని రూట్ కోసం fallback ను యాడ్ చేస్తాము.
function updateRoute() {
const path = window.location.pathname;
const route = routes[path];
if (!route) {
return navigate('/login');
}
const template = document.getElementById(route.templateId);
const view = template.content.cloneNode(true);
const app = document.getElementById('app');
app.innerHTML = '';
app.appendChild(view);
}ముఖ్యమైన విషయాలు గుర్తుంచుకోండి:
- ప్రస్తుత పాత్ కు ఒక రూట్ ఉందా అని తశీల్దారీ చేస్తుంది
- తప్పు రూట్ ఎక్కినప్పుడు login పేజీకి రీడైరెక్ట్ చేస్తుంది
- బ్రోకెన్ నావిగేషన్ను నివారించే fallback మెకానిజమ్ ఇస్తుంది
- తప్పు URL ఉన్నా కూడా యూజర్లు సరైన స్క్రీన్ చూడలేకపోవడాన్ని నిరోధిస్తుంది
రూట్ కనబడనప్పుడు ఇప్పుడు login పేజీకి రీడైరెక్ట్ చేస్తాం.
ఇప్పుడు లింకు క్లిక్ అయినపుడు URL తీసుకునే మరియు బ్రౌజర్ డిఫాల్ట్ లింకు ప్రవర్తన ఆపే ఫంక్షన్ సృష్టిద్దాం:
function onLinkClick(event) {
event.preventDefault();
navigate(event.target.href);
}ఈ క్లిక్ హ్యాండ్లర్ ను విడదీసి చూద్దాం:
preventDefault()ఉపయోగించి బ్రౌజర్ డిఫాల్ట్ లింకు ప్రవర్తన నివారిస్తుంది- క్లిక్ చేసిన లింక్ ఎలిమెంట్ నుండి గమ్యస్థానం URLని తీసుకుంటుంది
- పేజీ రీలోడ్ లేకుండా మన కస్టమ్ navigate ఫంక్షన్ను పిలుస్తుంది
- సాఫీ సింగిల్-పేజీ యాప్ అనుభవం జారకుండా ఉంచుతుంది
<a href="/dashboard" onclick="onLinkClick(event)">Login</a>
...
<a href="/login" onclick="onLinkClick(event)">Logout</a>onclick బైండింగ్ వల్ల కలిగే లాభాలు:
- ప్రతి లింకుని మన కస్టమ్ నావిగేషన్ సిస్టమ్ కి కనెక్ట్ చేస్తుంది
- క్లిక్ ఈవెంట్ ని ప్రాసెస్ కోసం
onLinkClickకి పాస్ చేస్తుంది - పేజీ రీలోడ్ లేకుండా సాఫీ నావిగేషన్ అనుమతిస్తుంది
- యూజర్లు బుక్మార్క్ చేసుకునే లేదా పంచుకునే సరైన URL స్ట్రక్చర్ ఉంచుతుంది
onclick అట్రిబ్యూట్ click ఈవెంట్ను జావాస్క్రిప్ట్ కోడ్ (ఇక్కడ navigate() ఫంక్షన్ కాల్) కి బైండ్ చేస్తుంది.
ఈ లింకులు మీద క్లిక్ చేసి చూడండి, మీరు ఇప్పుడు మీ యాప్ యొక్క వివిధ స్క్రీన్స్ మధ్య నావిగేట్ చేయగలుగుతారు.
✅ history.pushState మెథడ్ HTML5 స్టాండర్డ్ లో భాగం మరియు సకల ఆధునిక బ్రౌజర్లలో అమలైనది. మీరు పాత బ్రౌజర్ల కోసం వెబ్ యాప్ నిర్మిస్తున్నట్లైతే, ఈ API స్థానంలో మీరు ఉపయోగించగల ట్రిక్ ఉంది: పాత్ ముందు హ్యాష్ (#) ఉపయోగించి సాధారణ యాంకర్ నావిగేషన్ తో పని చేసే, పేజీను రీలోడ్ చేయని రూటింగ్ ను అమలు చేయవచ్చు.
వెబ్ బ్రౌజింగ్కు బ్యాక్ మరియు ఫార్వర్డ్ బటన్లు అనివార్యంగా ఉంటాయి, నాసా మిషన్ కంట్రోలు మునుపటి సిస్టమ్ స్థితులు పరిశీలించే విధంగా. యూజర్లు ఈ బటన్లు పనిచేయాలని ఆశిస్తారు; అవి పనికిరాలనప్పుడు బ్రౌజింగ్ అనుభవం చెడిపోతుంది.
మన సింగిల్-పేజీ యాప్ దీనికి మించిన కాన్ఫిగరేషన్ అవసరం. బ్రౌజర్ హిస్టరీ స్టాక్ ను నిర్వహిస్తుంది (దాన్ని మనం history.pushState తో జతచేస్తున్నాము), కానీ యూజర్లు ఈ హిస్టరీలో నావిగేట్ చేసే సమయంలో, మన యాప్ ప్రదర్శించబడుతున్న కంటెంట్ ను అప్డేట్ చేయాలి.
sequenceDiagram
participant User
participant Browser
participant App
participant Template
User->>Browser: "లాగిన్" లింక్ క్లిక్ చేస్తారు
Browser->>App: onclick ఈవెంట్ ప్రారంభించడమె
App->>App: preventDefault() & navigate('/dashboard')
App->>Browser: history.pushState('/dashboard')
Browser->>Browser: URL /dashboard కి అప్డేట్ అవుతుంది
App->>App: updateRoute() పిలవబడింది
App->>Template: డాష్బోర్డ్ టెంప్లేట్ వెతకండి & క్లోన్ చేయండి
Template->>App: క్లోన్ చేసిన కంటెంట్ రిటర్న్ చేయండి
App->>Browser: యాప్ కంటెంట్ ని టెంప్లేట్ తో మార్చండి
Browser->>User: డాష్బోర్డ్ స్క్రీన్ ప్రదర్శించండి
Note over User,Template: యూజర్ బ్రౌజర్ బ్యాక్ బటన్ క్లిక్ చేస్తారు
User->>Browser: బ్యాక్ బటన్ క్లిక్ చేస్తారు
Browser->>Browser: హిస్టరీ /login కి వెనుకకు పోవడం
Browser->>App: popstate ఈవెంట్ ఫైర్ అయింది
App->>App: updateRoute() ఆటోమాటిక్ పిలవబడింది
App->>Template: లాగిన్ టెంప్లేట్ వెతకండి & క్లోన్ చేయండి
Template->>App: క్లోన్ చేసిన కంటెంట్ రిటర్న్ చేయండి
App->>Browser: యాప్ కంటెంట్ ని టెంప్లేట్ తో మార్చండి
Browser->>User: లాగిన్ స్క్రీన్ ప్రదర్శించండి
ముఖ్యమైన ఇంటరాక్షన్ పాయింట్స్:
- యూజర్ చర్యలు క్లిక్లు లేదా బ్రౌజర్ బటన్ల ద్వారా నావిగేషన్ని ట్రిగ్గర్ చేస్తాయి
- అప్లికేషన్ పేజీ రీలోడ్లను నివారించడానికి లింక్ క్లిక్లను ఇన్టెర్సెప్టు చేస్తుంది
- హిస్టరీ API URL మార్పులు మరియు బ్రౌజర్ హిస్టరీ స్టాక్ ను నిర్వహిస్తుంది
- టెంప్లెట్లు ప్రతి స్క్రీన్ కు కంటెంట్ నిర్మాణాన్ని ప్రదానం చేస్తాయి
- ఈవెంట్ లిస్నర్లు అన్ని రకాల నావిగేషన్స్ కి యాప్ స్పందించేటంటి నిర్ధారిస్తాయి
history.pushStateను ఉపయోగించడం బ్రౌజర్ నావిగేషన్ హిస్టరీలో కొత్త ఎంట్రీలను సృష్టిస్తుంది. మీరు బ్రౌజర్ బ్యాక్ బటన్ పట్టు ఉండడాన్ని చూస్తే ఇది ఇలా కనిపిస్తుంది:
మీరు బ్యాక్ బటన్ కొన్నిసార్లు క్లిక్ చేస్తే, ప్రస్తుత URL మారిపోతుంది మరియు హిస్టరీ అప్డేట్ అవ్వుతుంది, కానీ అదే టెంప్లెట్ కనబడుతూనే ఉంటుంది.
అందుకే యాప్ హిస్టరీ మారిన ప్రతి సారి updateRoute()ను పిలవవలసిన అవసరం ఉందని తెలియదు. history.pushState డాక్యుమెంటేషన్ చూస్తే, స్టేట్ మారినపుడు - అంటే మనం వేరే URLకు వచ్చిందని - popstate ఈవెంట్ ట్రిగ్గర్ అవుతుందని తెలుస్తుంది. మనం దీన్ని ఉపయోగించి సరి చేస్తాము.
యూజర్ బ్రౌజర్ హిస్టరీ మార్పుల సమయంలో ప్రదర్శిత టెంప్లెట్ ని అప్డేట్ చేయాలంటే, మనం కొత్త ఫంక్షన్ అటాచ్చి updateRoute()ని పిలవాలి. దీన్ని మన app.js ఫైల్ చివరలో చేస్తాము:
window.onpopstate = () => updateRoute();
updateRoute();ఈ హిస్టరీ ఇంటిగ్రేషన్ అవగాహన:
- యూజర్లు బ్రౌజర్ బటన్లు ద్వారా నావిగేట్ చేసినప్పుడు వచ్చే
popstateఈవెంట్లను శ్రవణం చేస్తుంది - కాంసైస్ ఈవెంట్ హ్యాండ్లర్ సింటాక్స్ కోసం ఆర్రో ఫంక్షన్ వాడుతున్నది
- హిస్టరీ స్టేట్ మారినప్పుడు ఆటోమేటిక్గా
updateRoute()పిలవబడుతుంది - పేజీ మొదట్లో లోడ్ అయ్యేటప్పుడు యాప్ను ప్రారంభించడం కోసం కూడా
updateRoute()పిలుస్తుంది - యూజర్లు ఎట్లా నావిగేట్ చేసినా సరైన టెంప్లెట్ ప్రదర్శన ఖచ్చితంగా ఉంటుందనడాన్ని నిర్ధారిస్తుంది
💡 ప్రో టిప్: ఇక్కడ conciseness కోసం ఆర్రో ఫంక్షన్ వాడాము, కానీ సాదారణ ఫంక్షన్ కూడా సరే.
ఆర్రో ఫంక్షన్ పై రిఫ్రెషర్ వీడియో:
🎥 పై చిత్రాన్ని క్లిక్ చేస్తే ఆర్రో ఫంక్షన్ గురించి వీడియో మొదలవుతుంది.
ఇప్పుడు మీ బ్రౌజర్ బ్యాక్, ఫార్వర్డ్ బటన్లు ఉపయోగించి చూడండి, ఈ సారీ ప్రదర్శిత రూట్ సరిగా అప్డేట్ అవ్వబోతుంది.
- మీ బ్యాంకింగ్ యాప్ నావిగేషన్ను బ్రౌజర్ బ్యాక్/ఫార్వర్డ్ బటన్లు ఉపయోగించి పరీక్షించండి
- అడ్రస్ బార్లో వేరు వేరు URLs ను మాన్యువాగా టైప్ చేసి రూటింగ్ని పరీక్షించండి
- బ్రౌజర్ డెవ్టూల్స్ ఓపెన్ చేసి టెంప్లేట్లు DOMలో ఎలా క్లోన్ అవుతున్నాయో పరిశీలించండి
- రూటింగ్ ఫ్లో గమనించడానికి 콘솔.లాగ్ స్టేట్మెంట్లు జోడించి ప్రయోగించండి
- పోస్ట్-పాఠ్య క్విజ్ పూర్తి చేసి SPA ఆర్కిటెక్చర్ కాన్సెప్ట్లు అర్థం చేసుకోండి
- మీ బ్యాంకింగ్ యాప్ టెంప్లేట్లను ప్రొఫెషనల్గా చూడడానికి CSS స్టైలింగ్ జోడించండి
- సరైన లోప నిర్వహణతో 404 లోప పేజీ ఛాలెంజ్ అమలు చేయండి
- అదనపు రూటింగ్ ఫంక్షನాలిటీతో క్రెడిట్స్ పేజీ ఛాలెంజ్ క్రియేట్ చేయండి
- టెంప్లేట్ మార్పుల మధ్య లోడింగ్ స్టేట్స్ మరియు ట్రాన్సిషన్స్ జోడించండి
- ఫారమ్లు, డేటా నిర్వహణ, నిల్వతో పూర్తి బ్యాంకింగ్ యాప్ తయారు చేయండి
- రూట్ పరామితులు మరియు నెస్టెడ్ రూట్స్ వంటి అధునాతన రూటింగ్ ఒకటే చేసి జోడించండి
- నావిగేషన్ గార్డులు మరియు ప్రామాణికత ఆధారిత రూటింగ్ అమలు చేయండి
- తిరిగి ఉపయోగించగల టెంప్లేట్ భాగాలు మరియు కంపొనెంట్ లైబ్రరీ సృష్టించండి
- మెమరీ యూజర్ అనుభవం కోసం యానిమేషన్లు మరియు ట్రాన్సిషన్స్ జోడించండి
- SPAని హోస్టింగ్ ప్లాట్ఫారమ్ పై డిప్లాయ్ చేసి రూటింగ్ సరిచేయండి
- React, Vue, Angular వంటి ఆధునిక ఫ్రేమ్వర్క్లతో కాంప్లెక్స్ SPAలు అభివృద్ధి చేయండి
- అధునాతన స్టేట్ మేనేజ్మెంట్ ప్యాటర్న్స్ మరియు లైబ్రరీలను నేర్చుకోండి
- SPA అభివృద్ధి కోసం బిల్డ్ టూల్స్ మరియు డెవలప్మెంట్ వర్క్ఫ్లో బాగా క掌ించండి
- ప్రోగ్రెసివ్ వెబ్ యాప్ ఫీచర్లను మరియు ఆఫ్లైన్ ఫంక్షనాలిటీని అమలు చేయండి
- పెద్ద ఎత్తున SPA పర్ఫార్మెన్స్ ఆప్టిమైజేషన్ సాంకేతికతలను అధ్యయనం చేయండి
- ఓపెన్ సోర్స్ SPA ప్రాజెక్టులకు సహాయం చేయండి మరియు మీ జ్ఞానం పంచుకోండి
timeline
title SPA అభివృద్ధి & ఆధునిక వెబ్ శిల్పన ఏర్పాటు అభ్యసన ప్రగతి
section మౌలికం (20 నిమిషాలు)
టెంప్లేట్ సిస్టమ్స్: HTML టెంప్లేట్ ఎలిమెంట్స్
: DOM మానిప్యులేషన్
: కంటెంట్ క్లోనింగ్
: డైనమిక్ రెండరింగ్
section రౌటింగ్ ప్రాథమికాలు (30 నిమిషాలు)
క్లయింట్-సైడ్ నావిగేషన్: URL నిర్వహణ
: హిస్టరీ API
: రూట్ మ్యాపింగ్
: ఈవెంట్ హ్యాండ్లింగ్
section వినియోగదారు అనుభవం (40 నిమిషాలు)
నావిగేషన్ పాలిష్: బ్రౌజర్ ఇంటిగ్రేషన్
: బ్యాక్ బటన్ సపోర్ట్
: లోపం నిర్వహణ
: స్మూత్ ట్రాన్సిషన్స్
section శిల్పన నమూనాలు (50 నిమిషాలు)
ప్రొఫెషనల్ SPAs: కాంపONENT systems
: స్టేట్ నిర్వహణ
: పనితీరు అభివృద్ధి
: లోపి బౌండరీలు
section అభివృద్ధి సాంకేతికతలు (1 వారం)
ఫ్రేమ్వర్క్ ఇంటిగ్రేషన్: React Router
: Vue Router
: Angular Router
: స్టేట్ లైబ్రరీలు
section ఉత్పత్తి నైపుణ్యాలు (1 నెల)
సంస్థాభివృద్ధి: బిల్డ్ సిస్టమ్స్
: పరీక్షన విధానాలు
: డిప్లాయ్మెంట్ పైప్లైన్లు
: పనితీరు మానిటరింగ్
ఈ పాఠం పూర్తి చేసిన తర్వాత, మీరు ఈ విషయాల్లో మాస్టర్ అయ్యారు:
- టెంప్లేట్ ఆర్కిటెక్చర్: డైనమిక్ కంటెంట్ రెండరింగ్తో తిరిగి ఉపయోగించగల HTML భాగాలు
- క్లయింట్-సైడ్ రూటింగ్: పేజీ రీలోడ్లకు లేకుండా URL నిర్వహణ మరియు నావిగేషన్
- బ్రౌజర్ ఇంటిగ్రేషన్: హిస్టరీ API ఉపయోగం మరియు బ్యాక్/ఫార్వర్డ్ బటన్ల మద్దతు
- ఈవెంట్-ఆధారిత సిస్టమ్స్: నావిగేషన్ నిర్వహణ మరియు యూజర్ ఇంటరాక్షన్ మేనేజ్మెంట్
- DOM మేనేజ్మెంట్: టెంప్లేట్ క్లోనింగ్, కంటెంట్ మార్పిడి మరియు ఎలిమెంట్ నిర్వహణ
- లోప నిర్వహణ: తప్పు రూటులు మరియు లేని కంటెంట్ కోసం గౌరవనీయ fallbackలు
- పర్ఫార్మెన్స్ ప్యాటర్న్స్: సమర్ధవంతమైన కంటెంట్ లోడింగ్ మరియు రెండరింగ్ వ్యూహాలు
వాస్తవ ప్రపంచ అనువర్తనాలు: మీ SPA అభివృద్ధి నైపుణ్యాలు ప్రత్యక్షంగా వర్తిస్తాయి:
- ఆధునిక వెబ్ అప్లికేషన్స్: React, Vue, Angular, మరియు ఇతర ఫ్రేమ్వర్క్ల అభివృద్ధి
- ప్రోగ్రెసివ్ వెబ్ అప్స్: ఆఫ్లైన్ సామర్థ్యాలతో యాప్లాగా అనుభవాలు కలిగించే అప్లికేషన్స్
- ఎంటర్ప్రైజ్ డ్యాష్బోర్డ్స్: బహుముఖ వ్యవహారాపరమైన అనువర్తనాలు
- ఈ-కామర్స్ ప్లాట్ఫారమ్స్: ఉత్పత్తి కాటలాగ్లు, షాపింగ్ కార్ట్లు మరియు చెక్ అవుట్ ఫ్లోస్
- కంటెంట్ నిర్వహణ: డైనమిక్ కంటెంట్ సృష్టి మరియు ఎడిటింగ్ ఇంటర్వేసులు
- మొబైల్ అభివృద్ధి: వెబ్ టెక్నాలజీలతో హైబ్రిడ్అప్లు
ప్రొఫెషనల్ నైపుణ్యాలు పొందారు: ఇప్పుడు మీరు చేయగలరు:
- సINGLE-పేజీ యాప్లను ఆర్కిటెక్చర్ చేయండి సరైన బాధ్యత విభజనతో
- క్లయింట్-సైడ్ రూటింగ్ సిస్టమ్లను అమలు చేయండి యాప్ సంక్లిష్టత పెరిగిన కొద్దీ స్కేల్ అయ్యే విధంగా
- బ్రౌజర్ డెవలపర్ టూల్స్ సహాయంతో క్లిష్ట నావిగేషన్ ప్రవాహాలను డీబగ్ చేయండి
- టెంప్లేట్ నిర్వహణను సమర్ధవంతంగా చేయడం ద్వారా యాప్ పనితీరు ఆప్టిమైజ్ చేయండి
- ప్రొవైన native మరియు ప్రతిస్పందనాత్మక అనుభవాలను రూపొందించండి
ఫ్రంట్ఎండ్ అభివృద్ధి కాన్సెప్ట్లలో నైపుణ్యం:
- కంపోనెంట్ ఆర్కిటెక్చర్: పునర్వినియోగపరచదగిన UI నమూనాలు మరియు టెంప్లేట్ సిస్టమ్స్
- స్టేట్ సమకాలీకరణ: URL స్టేట్ నిర్వహణ మరియు బ్రౌజర్ హిస్టరీ
- ఈవెంట్-చలన ప్రోగ్రామింగ్: వినియోగదారుల ఇంటరాక్షన్ హ్యాండ్లింగ్ మరియు నావిగేషన్
- పర్ఫార్మెన్స్ ఆప్టిమైజేషన్: సమర్ధవంతమైన DOM మానిప్యులేషన్ మరియు కంటెంట్ లోడింగ్
- యూజర్ అనుభవ డిజైన్: సాఫీ ట్రాంజిషన్లు మరియు సులభమైన నావిగేషన్
తరువాతి స్థాయి: మీరు ఆధునిక ఫ్రంట్ఎండ్ ఫ్రేమ్వర్క్లు, అడ్వాన్స్డ్ స్టేట్ మేనేజ్మెంట్ లేదా క్లిష్ట ఎంటర్ప్రైజ్ యాప్లను ఎక్ప్లోర్ చేసే ప్రత్యేకంగా సిద్దంగా ఉన్నారు!
🌟 సాధన సాఫల్యం: మీరు ఆధునిక వెబ్ ఆర్కిటెక్చర్ నమూనాలతో ఒక ప్రొఫెషనల్ సింగిల్-పేజీ యాప్ బేస్ను నిర్మించారు!
ఏజెంట్ మోడ్ ఉపయోగించి క్రింది ఛాలెంజ్ను పూర్తి చేయండి:
వివరణ: బ్యాంకింగ్ యాప్ను మెరుగుపరచండి ఎర్రర్ హ్యాండ్లింగ్ మరియు 404 పేజీ టెంప్లేట్ను అమలు చేసి చెల్లని రూట్స్కు యూజర్ అనుభవాన్ని మెరుగుపరచండి.
ప్రాంప్ట్: id "not-found" తో ఒక కొత్త HTML టెంప్లేట్ రాబట్టండి, ఇది యూజర్-ఫ్రెండ్లీ 404 ఎర్రర్ పేజీగా స్టైలింగ్తో కనిపించాలి. ఆ తరువాత జావాస్క్రిప్ట్ రూటింగ్ లాజిక్ను మార్చండి ఇది చెల్లని URLs కు వెళ్ళినప్పుడు ఈ టెంప్లేట్ చూపిస్తుంది, మరియు "Go Home" బటన్ను జోడించండి ఇది లాగిన్ పేజీకి తిరిగి నావిగేట్ అవుతుంది.
మరింత తెలుసుకోండి agent మోడ్ గురించి ఇక్కడ.
ఈ యాప్ క్రెడిట్స్ చూపించే మూడవ పేజీ కోసం కొత్త టెంప్లేట్ మరియు రూట్ జోడించండి.
చాలెంజ్ లక్ష్యాలు:
- సృష్టించండి సరైన కంటెంట్ నిర్మాణంతో కొత్త HTML టెంప్లేట్
- జోడించండి కొత్త రూట్ను మీ రూట్స్ కాన్ఫిగరేషన్ ఆబ్జెక్ట్కు
- సంవంధించండి క్రెడిట్స్ పేజీకి సంబంధించిన నావిగేషన్ లింకులను
- పరీక్షించండి బ్రౌజర్ హిస్టరీతో అన్ని నావిగేషన్ సక్రమంగా పనిచేస్తున్నాయా
రూటింగ్ వెబ్ అభివృద్ధి లో ఆశ్చర్యకరంగా క్లిష్టమైన భాగాలలో ఒకటి, ప్రత్యేకంగా వెబ్ పేజీ రిఫ్రెష్ ప్రవర్తనలనుండి సింగిల్ పేజీ అప్లికేషన్ పేజీ రిఫ్రెష్లకు మారుతుండగా. Azure Static Web App సేవ ఎలా రూటింగ్ నిర్వహిస్తుందో కొంత చదవండి. ఆ డాక్యుమెంట్ లో వివరించబడిన కొన్ని నిర్ణయాలు ఎందుకు అవసరమో మీరు వివరించగలరా?
అదనపు నేర్చుకునే వనరులు:
- అన్వేషించండి React Router మరియు Vue Router వంటి ప్రాచుర్యం పొందిన ఫ్రేమ్వర్క్లు క్లయింట్-సైడ్ రూటింగ్ను ఎలా అమలు చేస్తున్నాయో
- ఆశీలించండి హాష్-ఆధారిత రూటింగ్ మరియు హిస్టరీ API రూటింగ్ మధ్య తేడాలు ఏం ఉన్నాయి
- అవగాహన పొందండి సర్వర్-సైడ్ రెండరింగ్ (SSR) మరియు అది రూటింగ్ వ్యూహాలపై ఎఫెక్ట్ ఎలా చూపుతుందో
- తెలుసుకోండి ప్రోగ్రెసివ్ వెబ్ యాప్స్ (PWAs) రూటింగ్ మరియు నావిగేషన్ను ఎలా నిర్వహిస్తాయో
అస్పష్టం:
ఈ దస్త్రాన్ని AI అనువాద సేవ Co-op Translator ఉపయోగించి అనువదించారు. మనము ఖచ్చితత్వం కోసం ప్రయత్నిస్తున్నప్పటికీ, ఆటోమేటెడ్ అనువాదాల్లో పొరపాట్లు లేదా తప్పుడు వివరాలు ఉండొచ్చు. మూల భాషలో ఉన్న అచ్ఛుతమైన డాక్యుమెంట్ను నమ్మకమైన మూలంగా పరిగణించాలి. కీలక సమాచారం కోసం, ప్రొఫెషనల్ మానవ అనువాదం చేయించుకోవడం మంచిది. ఈ అనువాదం వాడకం వల్ల వచ్చే ఏమైనా తప్పుగా అర్థం చేసుకోవడం లేదా పొరపాట్ల కోసం మేము బాధ్యులేమీ కాదు.

