|
3 weeks ago | |
---|---|---|
.. | ||
README.md | 3 weeks ago | |
assignment.md | 4 weeks ago |
README.md
बँकिंग अॅप तयार करा भाग 1: वेब अॅपमध्ये HTML टेम्पलेट्स आणि रूट्स
पूर्व-व्याख्यान क्विझ
परिचय
ब्राउझरमध्ये जावास्क्रिप्ट आल्यापासून, वेबसाइट्स अधिक इंटरॅक्टिव्ह आणि जटिल होत आहेत. वेब तंत्रज्ञानाचा आता पूर्णपणे कार्यक्षम अॅप्लिकेशन्स तयार करण्यासाठी वापर केला जातो, जे थेट ब्राउझरमध्ये चालतात आणि त्यांना वेब अॅप्लिकेशन्स म्हणतात. वेब अॅप्स अत्यंत इंटरॅक्टिव्ह असल्यामुळे, वापरकर्त्यांना प्रत्येक क्रिया केल्यानंतर संपूर्ण पृष्ठ पुन्हा लोड होण्याची वाट पाहायची नसते. म्हणूनच, जावास्क्रिप्टचा वापर HTML थेट अपडेट करण्यासाठी केला जातो, ज्यामुळे वापरकर्त्याचा अनुभव अधिक गुळगुळीत होतो.
या धड्यात, आपण HTML टेम्पलेट्स वापरून बँक वेब अॅप तयार करण्याची पायाभूत रचना तयार करणार आहोत, ज्यामुळे संपूर्ण HTML पृष्ठ पुन्हा लोड न करता एकाधिक स्क्रीन तयार करता येतील आणि अपडेट करता येतील.
पूर्वअट
आपल्याला या धड्यात तयार होणाऱ्या वेब अॅपची चाचणी घेण्यासाठी स्थानिक वेब सर्व्हरची आवश्यकता आहे. जर तुमच्याकडे नसल्यास, तुम्ही 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>
HTML टेम्पलेट्स
जर तुम्हाला वेब पृष्ठासाठी एकाधिक स्क्रीन तयार करायच्या असतील, तर एक उपाय म्हणजे तुम्हाला प्रत्येक स्क्रीनसाठी स्वतंत्र HTML फाइल तयार करावी लागेल. मात्र, या पद्धतीत काही अडचणी आहेत:
- स्क्रीन स्विच करताना संपूर्ण HTML पुन्हा लोड करावी लागते, ज्यामुळे प्रक्रिया मंदावते.
- वेगवेगळ्या स्क्रीनमध्ये डेटा शेअर करणे कठीण होते.
यासाठी दुसरा दृष्टिकोन म्हणजे फक्त एक HTML फाइल ठेवणे आणि <template>
घटकाचा वापर करून एकाधिक HTML टेम्पलेट्स परिभाषित करणे. टेम्पलेट म्हणजे पुनर्वापर करता येणारा HTML ब्लॉक आहे, जो ब्राउझरद्वारे प्रदर्शित केला जात नाही आणि रनटाइमवर जावास्क्रिप्ट वापरून त्याची प्रत तयार करावी लागते.
कार्य
आता आपण बँक अॅप तयार करू, ज्यामध्ये दोन स्क्रीन असतील: लॉगिन पृष्ठ आणि डॅशबोर्ड. प्रथम, HTML बॉडीमध्ये एक प्लेसहोल्डर घटक जोडा, जो आपल्या अॅपच्या वेगवेगळ्या स्क्रीन प्रदर्शित करण्यासाठी वापरला जाईल:
<div id="app">Loading...</div>
आम्ही त्याला id
दिले आहे, जेणेकरून नंतर जावास्क्रिप्टद्वारे त्याला शोधणे सोपे जाईल.
टीप: या घटकाची सामग्री बदलली जाणार असल्याने, आपण त्यात लोडिंग संदेश किंवा इंडिकेटर ठेवू शकतो, जो अॅप लोड होत असताना दिसेल.
यानंतर, लॉगिन पृष्ठासाठी HTML टेम्पलेट जोडा. सध्या, आपण फक्त एक शीर्षक आणि एक विभाग ठेवू, ज्यामध्ये नेव्हिगेशनसाठी लिंक असेल.
<template id="login">
<h1>Bank App</h1>
<section>
<a href="/dashboard">Login</a>
</section>
</template>
यानंतर, डॅशबोर्ड पृष्ठासाठी आणखी एक 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>
टीप: HTML टेम्पलेट्स तयार करताना, जर तुम्हाला ते कसे दिसेल हे पाहायचे असेल, तर
<template>
आणि</template>
ओळी<!-- -->
ने कॉमेंट करून पाहू शकता.
✅ तुमच्या मते, आपण टेम्पलेट्सवर id
ऍट्रिब्युट्स का वापरतो? आपण त्याऐवजी वर्ग (classes) वापरू शकतो का?
जावास्क्रिप्टसह टेम्पलेट्स प्रदर्शित करणे
जर तुम्ही तुमची सध्याची HTML फाइल ब्राउझरमध्ये उघडली, तर ती Loading...
वर अडकलेली दिसेल. कारण आपल्याला HTML टेम्पलेट्स तयार करून प्रदर्शित करण्यासाठी काही जावास्क्रिप्ट कोड जोडावा लागेल.
टेम्पलेट तयार करणे सहसा 3 टप्प्यांमध्ये केले जाते:
- DOM मध्ये टेम्पलेट घटक शोधा, उदाहरणार्थ
document.getElementById
वापरून. - टेम्पलेट घटकाची प्रत तयार करा,
cloneNode
वापरून. - ती प्रत DOM मध्ये दृश्यमान घटकाखाली जोडा, उदाहरणार्थ
appendChild
वापरून.
✅ आपण टेम्पलेट जोडण्यापूर्वी त्याची प्रत का तयार करतो? जर आपण हा टप्पा वगळला तर काय होईल?
कार्य
तुमच्या प्रोजेक्ट फोल्डरमध्ये app.js
नावाची नवीन फाइल तयार करा आणि ती HTML च्या <head>
विभागात आयात करा:
<script src="app.js" defer></script>
आता 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);
}
येथे आपण वरील 3 टप्पे अचूकपणे पार पाडतो. आपण templateId
असलेल्या टेम्पलेटची प्रत तयार करतो आणि त्याची प्रत आपल्या अॅपच्या प्लेसहोल्डरमध्ये ठेवतो. लक्षात घ्या की संपूर्ण टेम्पलेट झाडाची प्रत तयार करण्यासाठी cloneNode(true)
वापरणे आवश्यक आहे.
आता या फंक्शनला एका टेम्पलेटसह कॉल करा आणि परिणाम पहा.
updateRoute('login');
✅ app.innerHTML = '';
या कोडचा उद्देश काय आहे? त्याशिवाय काय होते?
रूट्स तयार करणे
वेब अॅपबद्दल बोलताना, Routing म्हणजे URLs विशिष्ट स्क्रीनशी मॅप करणे, ज्या प्रदर्शित केल्या पाहिजेत. एकाधिक 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' },
};
आता updateRoute
फंक्शन थोडे बदलू. थेट templateId
पास करण्याऐवजी, आपण प्रथम सध्याचा URL पाहून, नंतर आपल्या नकाशाचा वापर करून संबंधित टेम्पलेट ID मूल्य मिळवू. window.location.pathname
वापरून URL मधून फक्त पथ विभाग मिळवता येतो.
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 मॅन्युअली बदलून ते योग्यरित्या कार्य करते का ते तपासा.
✅ जर तुम्ही URL मध्ये अज्ञात पथ प्रविष्ट केला तर काय होते? आपण हे कसे सोडवू शकतो?
नेव्हिगेशन जोडणे
आता आपल्या अॅपमध्ये URL मॅन्युअली बदलण्याशिवाय पृष्ठांदरम्यान नेव्हिगेट करण्याची क्षमता जोडायची आहे. याचा अर्थ दोन गोष्टी कराव्या लागतील:
- सध्याचा URL अपडेट करणे
- नवीन URL वर आधारित टेम्पलेट अपडेट करणे
दुसऱ्या भागासाठी आपण updateRoute
फंक्शन तयार केले आहे, त्यामुळे आता सध्याचा URL कसा अपडेट करायचा ते शोधायचे आहे.
आपल्याला जावास्क्रिप्ट वापरावी लागेल, विशेषतः history.pushState
, ज्यामुळे HTML पुन्हा लोड न करता URL अपडेट करता येतो आणि ब्राउझिंग इतिहासात नवीन नोंद तयार करता येते.
टीप: HTML अँकर घटक
<a href>
स्वतः URL साठी हायपरलिंक्स तयार करण्यासाठी वापरला जाऊ शकतो, परंतु तो डिफॉल्टनुसार HTML पुन्हा लोड करतो. कस्टम जावास्क्रिप्टसह रूटिंग हाताळताना,preventDefault()
फंक्शन वापरून हे वर्तन टाळणे आवश्यक आहे.
कार्य
आता आपल्या अॅपमध्ये नेव्हिगेट करण्यासाठी वापरता येईल अशी नवीन फंक्शन तयार करू:
function navigate(path) {
window.history.pushState({}, path, path);
updateRoute();
}
ही पद्धत दिलेल्या पथावर आधारित सध्याचा URL प्रथम अपडेट करते, नंतर टेम्पलेट अपडेट करते. window.location.origin
प्रॉपर्टी URL रूट परत करते, ज्यामुळे दिलेल्या पथावरून पूर्ण URL पुन्हा तयार करता येतो.
आता आपल्याकडे ही फंक्शन आहे, आपण रूटशी जुळणारा पथ सापडत नसल्यास असलेली समस्या सोडवू शकतो. आपण updateRoute
फंक्शन थोडे बदलू आणि जर जुळणारा रूट सापडला नाही, तर विद्यमान रूटपैकी एका रूटवर पुनर्निर्देशित करू.
function updateRoute() {
const path = window.location.pathname;
const route = routes[path];
if (!route) {
return navigate('/login');
}
...
जर रूट सापडला नाही, तर आता आपण login
पृष्ठावर पुनर्निर्देशित करू.
आता लिंक क्लिक केल्यावर URL मिळवण्यासाठी आणि ब्राउझरच्या डिफॉल्ट लिंक वर्तनास प्रतिबंध करण्यासाठी एक फंक्शन तयार करू:
function onLinkClick(event) {
event.preventDefault();
navigate(event.target.href);
}
आता आपल्या HTML मधील Login आणि Logout लिंक्ससाठी बाइंडिंग्ज जोडून नेव्हिगेशन सिस्टम पूर्ण करू.
<a href="/dashboard" onclick="onLinkClick(event)">Login</a>
...
<a href="/login" onclick="onLinkClick(event)">Logout</a>
वरील event
ऑब्जेक्ट, click
इव्हेंट कॅप्चर करते आणि ते आपल्या onLinkClick
फंक्शनला पास करते.
onclick
ऍट्रिब्युट वापरून click
इव्हेंट जावास्क्रिप्ट कोडशी बाइंड करा, येथे navigate()
फंक्शन कॉल.
या लिंक्सवर क्लिक करून पहा, आता तुम्ही तुमच्या अॅपच्या वेगवेगळ्या स्क्रीनमध्ये नेव्हिगेट करू शकता.
✅ history.pushState
पद्धत HTML5 मानकाचा भाग आहे आणि सर्व आधुनिक ब्राउझरमध्ये अंमलात आणली गेली आहे. जर तुम्ही जुन्या ब्राउझरसाठी वेब अॅप तयार करत असाल, तर या API च्या जागी एक युक्ती वापरता येते: पथापूर्वी हॅश (#
) वापरून तुम्ही रूटिंग अंमलात आणू शकता, जे नियमित अँकर नेव्हिगेशनसह कार्य करते आणि पृष्ठ पुन्हा लोड करत नाही.
ब्राउझरच्या बॅक आणि फॉरवर्ड बटणांशी हाताळणी
history.pushState
वापरल्याने ब्राउझरच्या नेव्हिगेशन इतिहासात नवीन नोंदी तयार होतात. तुम्ही ब्राउझरच्या बॅक बटण दाबून पाहू शकता, त्यात असे काहीतरी दिसेल:
जर तुम्ही बॅक बटणावर काही वेळा क्लिक केले, तर तुम्हाला दिसेल की सध्याचा URL बदलतो आणि इतिहास अपडेट होतो, परंतु त्याच टेम्पलेटचे प्रदर्शन सुरू राहते.
कारण अॅप्लिकेशनला माहित नाही की इतिहास बदलला की updateRoute()
कॉल करणे आवश्यक आहे. जर तुम्ही history.pushState
दस्तऐवज पाहिले, तर तुम्हाला दिसेल की जर स्थिती बदलली - म्हणजे आपण वेगळ्या URL वर गेलो - तर popstate
इव्हेंट ट्रिगर होतो. आपण ही समस्या सोडवण्यासाठी ते वापरणार आहोत.
कार्य
ब्राउझर इतिहास बदलल्यावर प्रदर्शित टेम्पलेट अपडेट होईल याची खात्री करण्यासाठी, आपण updateRoute()
कॉल करणारे नवीन फंक्शन जोडू. हे app.js
फाइलच्या तळाशी जोडू:
window.onpopstate = () => updateRoute();
updateRoute();
टीप: येथे आम्ही ऍरो फंक्शन वापरून आमचा
popstate
इव्हेंट हँडलर जाहीर केला आहे, परंतु नियमित फंक्शन देखील त्याचप्रमाणे कार्य करेल.
ऍरो फंक्शन्सवरील व्हिडिओसाठी येथे एक रिफ्रेशर आहे:
🎥 वरील प्रतिमेवर क्लिक करा ऍरो फंक्शन्सबद्दल व्हिडिओसाठी.
आता ब्राउझरच्या बॅक आणि फॉरवर्ड बटणांचा वापर करून पहा आणि यावेळी प्रदर्शित रूट योग्यरित्या अपडेट होत आहे का ते तपासा.
🚀 आव्हान
या अॅपसाठी क्रेडिट्स दर्शवणारे तिसऱ्या पृष्ठासाठी नवीन टेम्पलेट आणि रूट जोडा.
व्याख्यानानंतरचा क्विझ
पुनरावलोकन आणि स्व-अभ्यास
रूटिंग हे वेब डेव्हलपमेंटमधील आश्चर्यकारकपणे गुंतागुंतीचे भागांपैकी एक आहे, विशेषतः वेब पृष्ठ रिफ्रेश वर्तनांपासून सिंगल पेज अॅप्लिकेशन पृष्ठ रिफ्रेशकडे जात असताना. Azure Static Web App सेवा रूटिंग कसे हाताळते याबद्दल थोडे वाचा. त्या दस्तऐवजावर वर्णन केलेल्या काही निर्णयांची आवश्यकता का आहे हे तुम्ही स्पष्ट करू शकता का?
असाइनमेंट
अस्वीकरण:
हा दस्तऐवज AI भाषांतर सेवा Co-op Translator वापरून भाषांतरित करण्यात आला आहे. आम्ही अचूकतेसाठी प्रयत्नशील असलो तरी कृपया लक्षात ठेवा की स्वयंचलित भाषांतरांमध्ये त्रुटी किंवा अचूकतेचा अभाव असू शकतो. मूळ भाषेतील दस्तऐवज हा अधिकृत स्रोत मानला जावा. महत्त्वाच्या माहितीसाठी व्यावसायिक मानवी भाषांतराची शिफारस केली जाते. या भाषांतराचा वापर करून उद्भवलेल्या कोणत्याही गैरसमज किंवा चुकीच्या अर्थासाठी आम्ही जबाबदार राहणार नाही.