मराठी

जावास्क्रिप्ट टेम्पोरल API साठी एक सखोल मार्गदर्शक, जे विविध आंतरराष्ट्रीय संदर्भांमध्ये तारखा आणि वेळा प्रभावीपणे हाताळण्यासाठी एक आधुनिक उपाय आहे.

जावास्क्रिप्ट टेम्पोरल API: जागतिक प्रेक्षकांसाठी आधुनिक तारीख आणि वेळ हाताळणी

जावास्क्रिप्ट `Date` ऑब्जेक्ट डेव्हलपर्ससाठी बऱ्याच काळापासून त्रासाचे कारण ठरले आहे. त्याची म्युटेबिलिटी (mutability), विसंगत API, आणि खराब टाइमझोन सपोर्टमुळे Moment.js आणि date-fns सारख्या अनेक लायब्ररीचा वापर करावा लागत होता. आता, टेम्पोरल API सह, जावास्क्रिप्टने स्पष्टता आणि अचूकतेसह तारखा आणि वेळा हाताळण्यासाठी एक आधुनिक, इन-बिल्ट उपाय ऑफर केला आहे. हा लेख टेम्पोरल API चा सर्वसमावेशक आढावा देतो, ज्यात त्याची वैशिष्ट्ये, फायदे आणि विविध आंतरराष्ट्रीय संदर्भांमधील वापरांवर लक्ष केंद्रित केले आहे.

टेम्पोरल API म्हणजे काय?

टेम्पोरल API हे जावास्क्रिप्टमधील एक नवीन, ग्लोबल ऑब्जेक्ट आहे जे `Date` ऑब्जेक्टच्या उणिवा दूर करण्यासाठी डिझाइन केलेले आहे. हे तारखा, वेळा, टाइम झोन आणि कॅलेंडर प्रणालींसोबत काम करण्यासाठी एक स्वच्छ, अपरिवर्तनीय (immutable) API प्रदान करते. महत्त्वाचे म्हणजे, हे तारीख आणि वेळेच्या संकल्पनांना वास्तविक जगाच्या वापराशी आणि अपेक्षांशी अधिक जवळून जुळवून घेण्याच्या पद्धतीने सादर करण्याचा प्रयत्न करते, ज्यामुळे आंतरराष्ट्रीयीकरण (internationalization) अधिक सोपे होते.

मुख्य वैशिष्ट्ये:

मूलभूत टेम्पोरल ऑब्जेक्ट्स

टेम्पोरल API अनेक नवीन ऑब्जेक्ट प्रकारांची ओळख करून देते. येथे काही प्रमुख प्रकार दिले आहेत:

तारखांसोबत काम करणे

`Temporal.PlainDate` तयार करणे

`Temporal.PlainDate` तयार करण्यासाठी, तुम्ही कंस्ट्रक्टर वापरू शकता:

const plainDate = new Temporal.PlainDate(2024, 10, 27); // वर्ष, महिना (1-12), दिवस
console.log(plainDate.toString()); // आउटपुट: 2024-10-27

तुम्ही `from` पद्धत देखील वापरू शकता, जी ISO 8601 फॉरमॅटमधील स्ट्रिंग स्वीकारते:

const plainDateFromString = Temporal.PlainDate.from('2024-10-27');
console.log(plainDateFromString.toString()); // आउटपुट: 2024-10-27

तारीख घटक मिळवणे

तुम्ही `year`, `month`, आणि `day` सारख्या प्रॉपर्टीज वापरून वैयक्तिक तारीख घटक मिळवू शकता:

console.log(plainDate.year); // आउटपुट: 2024
console.log(plainDate.month); // आउटपुट: 10
console.log(plainDate.day); // आउटपुट: 27

तारखेचे गणित

दिवस, आठवडे, महिने किंवा वर्षे जोडण्यासाठी किंवा वजा करण्यासाठी, `plus` आणि `minus` पद्धती वापरा. या पद्धती नवीन `Temporal.PlainDate` ऑब्जेक्ट परत करतात:

const nextWeek = plainDate.plus({ days: 7 });
console.log(nextWeek.toString()); // आउटपुट: 2024-11-03

const lastMonth = plainDate.minus({ months: 1 });
console.log(lastMonth.toString()); // आउटपुट: 2024-09-27

तारखांची तुलना करणे

तुम्ही `compare` पद्धत वापरून तारखांची तुलना करू शकता:

const date1 = new Temporal.PlainDate(2024, 10, 27);
const date2 = new Temporal.PlainDate(2024, 11, 15);

console.log(Temporal.PlainDate.compare(date1, date2)); // आउटपुट: -1 (date1 ही date2 पेक्षा आधीची आहे)

वेळेसोबत काम करणे

`Temporal.PlainTime` तयार करणे

`Temporal.PlainTime` तयार करण्यासाठी, कंस्ट्रक्टर वापरा:

const plainTime = new Temporal.PlainTime(10, 30, 0); // तास, मिनिट, सेकंद
console.log(plainTime.toString()); // आउटपुट: 10:30:00

किंवा ISO 8601 टाइम स्ट्रिंगसह `from` पद्धत वापरा:

const plainTimeFromString = Temporal.PlainTime.from('10:30:00');
console.log(plainTimeFromString.toString()); // आउटपुट: 10:30:00

वेळेचे घटक मिळवणे

console.log(plainTime.hour); // आउटपुट: 10
console.log(plainTime.minute); // आउटपुट: 30
console.log(plainTime.second); // आउटपुट: 0

वेळेचे गणित

const later = plainTime.plus({ minutes: 15 });
console.log(later.toString()); // आउटपुट: 10:45:00

तारीख आणि वेळ एकत्र वापरणे

`Temporal.PlainDateTime` तयार करणे

तुम्ही `Temporal.PlainDateTime` थेट तयार करू शकता किंवा `Temporal.PlainDate` आणि `Temporal.PlainTime` एकत्र करून तयार करू शकता:

const plainDateTime = new Temporal.PlainDateTime(2024, 10, 27, 10, 30, 0);
console.log(plainDateTime.toString()); // आउटपुट: 2024-10-27T10:30:00

const date = new Temporal.PlainDate(2024, 10, 27);
const time = new Temporal.PlainTime(10, 30, 0);
const combinedDateTime = date.toPlainDateTime(time);
console.log(combinedDateTime.toString()); // आउटपुट: 2024-10-27T10:30:00

टाइम झोन

वेगवेगळ्या ठिकाणी असलेल्या वापरकर्त्यांशी व्यवहार करणाऱ्या ॲप्लिकेशन्ससाठी टाइम झोन योग्यरित्या हाताळणे महत्त्वाचे आहे. टेम्पोरल API `Temporal.ZonedDateTime` आणि `Temporal.TimeZone` ऑब्जेक्ट्सद्वारे मजबूत टाइम झोन सपोर्ट प्रदान करते.

`Temporal.ZonedDateTime` तयार करणे

`Temporal.ZonedDateTime` तयार करण्यासाठी, तुम्हाला `Temporal.PlainDateTime` आणि टाइम झोन आयडेंटिफायरची आवश्यकता आहे. टाइम झोन आयडेंटिफायर IANA टाइम झोन डेटाबेसवर आधारित आहेत (उदा., `America/Los_Angeles`, `Europe/London`, `Asia/Tokyo`).

const plainDateTime = new Temporal.PlainDateTime(2024, 10, 27, 10, 30, 0);
const timeZone = 'America/Los_Angeles';
const zonedDateTime = plainDateTime.toZonedDateTime(timeZone);
console.log(zonedDateTime.toString()); // आउटपुट: 2024-10-27T10:30:00-07:00[America/Los_Angeles] (ऑफसेट DST नियमांवर अवलंबून असेल)

वैकल्पिकरित्या, `Instant` वरून `Temporal.ZonedDateTime` तयार करा.

const instant = Temporal.Instant.fromEpochSeconds(1666866600); // उदाहरण टाइमस्टॅम्प
const zonedDateTimeFromInstant = instant.toZonedDateTimeISO(timeZone); // 'America/Los_Angeles' सारखा टाइमझोन
console.log(zonedDateTimeFromInstant.toString());

टाइम झोनमध्ये रूपांतरण

तुम्ही `withTimeZone` पद्धत वापरून `Temporal.ZonedDateTime` ला वेगळ्या टाइम झोनमध्ये रूपांतरित करू शकता:

const newTimeZone = 'Europe/London';
const zonedDateTimeInLondon = zonedDateTime.withTimeZone(newTimeZone);
console.log(zonedDateTimeInLondon.toString()); // आउटपुट: 2024-10-27T18:30:00+01:00[Europe/London]

टाइम झोन ऑफसेटसोबत काम करणे

`Temporal.TimeZone` ऑब्जेक्टची `getOffsetStringFor` पद्धत दिलेल्या `Temporal.Instant` साठी ऑफसेट स्ट्रिंग प्रदान करते:

const timeZoneObject = new Temporal.TimeZone(timeZone);
const offsetString = timeZoneObject.getOffsetStringFor(zonedDateTime.toInstant());
console.log(offsetString); // आउटपुट: -07:00 (DST नियमांवर अवलंबून)

अचूक गणनेसाठी योग्य IANA टाइम झोन आयडेंटिफायर वापरणे आवश्यक आहे. हे आयडेंटिफायर डेलाइट सेव्हिंग टाइम आणि टाइम झोन सीमांमधील बदल दर्शवण्यासाठी नियमितपणे सांभाळले जातात आणि अद्यतनित केले जातात.

कालावधी (Durations)

`Temporal.Duration` ऑब्जेक्ट वेळेचा कालावधी दर्शवतो. याचा उपयोग तारखा आणि वेळांमध्ये जोडण्यासाठी किंवा वजा करण्यासाठी केला जाऊ शकतो.

`Temporal.Duration` तयार करणे

तुम्ही कंस्ट्रक्टर वापरून, वर्षे, महिने, दिवस, तास, मिनिटे, सेकंद, मिलिसेकंद, मायक्रोसेकंद आणि नॅनोसेकंद निर्दिष्ट करून `Temporal.Duration` तयार करू शकता:

const duration = new Temporal.Duration(1, 2, 3, 4, 5, 6, 7, 8, 9); // वर्षे, महिने, दिवस, तास, मिनिटे, सेकंद, मिलिसेकंद, मायक्रोसेकंद, नॅनोसेकंद
console.log(duration.toString()); // आउटपुट: P1Y2M3DT4H5M6.007008009S

किंवा ISO 8601 ड्यूरेशन स्ट्रिंग वापरून:

const durationFromString = Temporal.Duration.from('P1Y2M3DT4H5M6S');
console.log(durationFromString.toString()); // आउटपुट: P1Y2M3DT4H5M6S

तारखा आणि वेळांमध्ये कालावधी जोडणे

const plainDate = new Temporal.PlainDate(2024, 10, 27);
const duration = new Temporal.Duration(0, 0, 7); // 7 दिवस
const newDate = plainDate.plus(duration);
console.log(newDate.toString()); // आउटपुट: 2024-11-03

लक्षात घ्या की तारखांमध्ये महिने किंवा वर्षे समाविष्ट असलेले कालावधी जोडताना काळजीपूर्वक विचार करणे आवश्यक आहे, कारण एका महिन्यात किंवा वर्षातील दिवसांची संख्या बदलू शकते.

कॅलेंडर सिस्टीम

टेम्पोरल API ग्रेगोरियन कॅलेंडरच्या पलीकडे विविध कॅलेंडर प्रणालींना समर्थन देते. विविध सांस्कृतिक संदर्भांमध्ये तारखा हाताळण्याची आवश्यकता असलेल्या ॲप्लिकेशन्ससाठी हे महत्त्वाचे आहे. जरी सपोर्ट अजूनही विकसित होत असला तरी, ते भविष्यातील विस्तारासाठी एक पाया प्रदान करते.

पर्यायी कॅलेंडर वापरणे

विशिष्ट कॅलेंडर वापरण्यासाठी, तुम्ही टेम्पोरल ऑब्जेक्ट्स तयार करताना ते निर्दिष्ट करू शकता:

const hebrewDate = new Temporal.PlainDate(5785, 1, 1, { calendar: 'hebrew' });
console.log(hebrewDate.toString()); // विशिष्ट आउटपुट अंमलबजावणी आणि स्वरूपनावर अवलंबून बदलू शकते. हे लिहिताना अनेक वातावरणात पॉलीफिलची आवश्यकता आहे.

महत्त्वाचे: नॉन-ग्रेगोरियन कॅलेंडरसाठी सपोर्टला पॉलीफिल किंवा विशिष्ट ब्राउझर/एन्व्हायरमेंट सपोर्टची आवश्यकता असू शकते. ताज्या माहितीसाठी टेम्पोरल API डॉक्युमेंटेशन आणि ब्राउझर कंपॅटिबिलिटी टेबल तपासा.

तारखा आणि वेळा फॉरमॅट करणे

टेम्पोरल API तारीख आणि वेळ हाताळण्यावर लक्ष केंद्रित करते, तर फॉरमॅटिंग सामान्यतः `Intl.DateTimeFormat` ऑब्जेक्टद्वारे हाताळले जाते, जे इंटरनॅशनलायझेशन API चा भाग आहे. टेम्पोरल ऑब्जेक्ट्स `Intl.DateTimeFormat` सोबत सहजतेने काम करतात.

`Intl.DateTimeFormat` वापरणे

`Intl.DateTimeFormat` वापरून `Temporal.PlainDate` कसे फॉरमॅट करायचे ते येथे दिले आहे:

const plainDate = new Temporal.PlainDate(2024, 10, 27);
const formatter = new Intl.DateTimeFormat('en-US', { year: 'numeric', month: 'long', day: 'numeric' });
console.log(formatter.format(plainDate)); // आउटपुट: October 27, 2024

const formatterGerman = new Intl.DateTimeFormat('de-DE', { year: 'numeric', month: 'long', day: 'numeric' });
console.log(formatterGerman.format(plainDate)); // आउटपुट: 27. Oktober 2024

तुम्ही तुमच्या गरजेनुसार फॉरमॅट पर्याय सानुकूलित करू शकता. `Intl.DateTimeFormat` चा पहिला युक्तिवाद म्हणजे लोकेल, जो फॉरमॅटिंगसाठी वापरल्या जाणार्‍या भाषा आणि प्रादेशिक परंपरा ठरवतो. भिन्न लोकेल वापरल्याने (उदा., 'en-US', 'de-DE', 'fr-FR', 'ja-JP') भिन्न आउटपुट फॉरमॅट्स तयार होतात.

`Temporal.ZonedDateTime` फॉरमॅट करणे

`Temporal.ZonedDateTime` फॉरमॅट करणे समान आहे, परंतु तुम्ही आउटपुटमध्ये टाइम झोन माहिती देखील समाविष्ट करू शकता:

const plainDateTime = new Temporal.PlainDateTime(2024, 10, 27, 10, 30, 0);
const timeZone = 'America/Los_Angeles';
const zonedDateTime = plainDateTime.toZonedDateTime(timeZone);

const formatter = new Intl.DateTimeFormat('en-US', { year: 'numeric', month: 'long', day: 'numeric', hour: 'numeric', minute: 'numeric', timeZoneName: 'short' });
console.log(formatter.format(zonedDateTime)); // आउटपुट: October 27, 2024, 10:30 AM PDT (टाइम झोनचे संक्षिप्त रूप DST नियमांवर अवलंबून असते)

आंतरराष्ट्रीयीकरणासाठी सर्वोत्तम पद्धती

जागतिक संदर्भात तारखा आणि वेळांसोबत काम करताना, खालील सर्वोत्तम पद्धती लक्षात ठेवा:

टेम्पोरल API ची जुन्या Date ऑब्जेक्टशी तुलना

येथे एक सारणी आहे जी जुन्या `Date` ऑब्जेक्टच्या तुलनेत टेम्पोरल API चे मुख्य फरक आणि फायदे हायलाइट करते:

वैशिष्ट्य जुना `Date` ऑब्जेक्ट टेम्पोरल API
म्युटेबिलिटी म्युटेबल (मूळ ऑब्जेक्टमध्ये बदल करते) इम्युटेबल (नवीन ऑब्जेक्ट्स परत करते)
टाइम झोन सपोर्ट मर्यादित आणि अनेकदा समस्याप्रधान मजबूत आणि अचूक, IANA टाइम झोन डेटाबेसवर आधारित
API विसंगत आणि वापरण्यास कठीण स्पष्ट, सुसंगत आणि अंतर्ज्ञानी
अचूकता मिलिसेकंद नॅनोसेकंद
कॅलेंडर सिस्टीम केवळ ग्रेगोरियनपुरते मर्यादित पर्यायी कॅलेंडर सिस्टीमला समर्थन देते (विकसित होत असलेल्या सपोर्टसह)
आंतरराष्ट्रीयीकरण मजबूत आंतरराष्ट्रीयीकरणासाठी बाह्य लायब्ररीची आवश्यकता आहे इन-बिल्ट सपोर्ट आणि `Intl.DateTimeFormat` सह अखंड एकीकरण

ब्राउझर सपोर्ट आणि पॉलीफिल्स

एक नवीन API असल्याने, टेम्पोरल API साठी ब्राउझर सपोर्ट अजूनही विकसित होत आहे. कोणते ब्राउझर आणि एन्व्हायरमेंट त्याला मूळतः समर्थन देतात हे पाहण्यासाठी नवीनतम ब्राउझर कंपॅटिबिलिटी टेबल (उदा. MDN वेब डॉक्सवर) तपासा. जुन्या ब्राउझर किंवा मूळ सपोर्ट नसलेल्या एन्व्हायरमेंटसाठी, तुम्ही टेम्पोरल API कार्यक्षमता प्रदान करण्यासाठी पॉलीफिल्स वापरू शकता. योग्य पर्याय शोधण्यासाठी वेबवर "टेम्पोरल API पॉलीफिल" शोधा.

निष्कर्ष

जावास्क्रिप्ट टेम्पोरल API हे जावास्क्रिप्टमध्ये तारखा आणि वेळा हाताळण्यात एक महत्त्वपूर्ण प्रगती दर्शवते. त्याची अपरिवर्तनीयता, स्पष्ट API, मजबूत टाइम झोन सपोर्ट आणि कॅलेंडर सिस्टीम क्षमतांमुळे हे अशा डेव्हलपर्ससाठी एक शक्तिशाली साधन बनते ज्यांना विविध आंतरराष्ट्रीय संदर्भांमध्ये अचूक आणि विश्वसनीयपणे तारखा आणि वेळांसोबत काम करण्याची आवश्यकता आहे. जरी ब्राउझर सपोर्ट अजूनही विकसित होत असला तरी, टेम्पोरल API चे फायदे ते नवीन प्रकल्पांसाठी शिकण्यासारखे आणि स्वीकारण्यासारखे बनवतात. टेम्पोरल API स्वीकारून आणि आंतरराष्ट्रीयीकरणाच्या सर्वोत्तम पद्धतींचे पालन करून, तुम्ही असे ॲप्लिकेशन्स तयार करू शकता जे जगभरातील वापरकर्त्यांना अखंड आणि अचूक तारीख आणि वेळेचा अनुभव देतात.

अधिक माहितीसाठी