Next.js एप्लिकेशन में, जो Pages Router का उपयोग कर रहा है, अंतरराष्ट्रीयकरण कैसे लागू करें
अपने React एप्लिकेशन को अधिक सुलभ बनाएं और अंतरराष्ट्रीयकरण (i18n) के साथ नए बाजारों तक पहुँचें।
जैसे-जैसे दुनिया अधिक वैश्वीकृत होती जा रही है, वेब डेवलपर्स के लिए यह बहुत ज़रूरी होता जा रहा है कि वे ऐसी एप्लिकेशन बनाएं जो विभिन्न देशों और संस्कृतियों के उपयोगकर्ताओं की आवश्यकताओं को पूरा कर सकें। इसे हासिल करने के प्रमुख तरीकों में से एक है अंतर्राष्ट्रीयकरण (i18n), जो आपको अपनी एप्लिकेशन को विभिन्न भाषाओं, मुद्राओं और तिथि प्रारूपों के अनुसार अनुकूलित करने की अनुमति देता है।
इस ट्यूटोरियल में, हम देखेंगे कि आप अपने React Next.js एप्लिकेशन में सर्वर साइड रेंडरिंग के साथ अंतर्राष्ट्रीयकरण कैसे जोड़ सकते हैं। TL;DR: पूरा उदाहरण यहाँ देखें।
यह मार्गदर्शिका उन Next.js अनुप्रयोगों के लिए है जो Pages Router का उपयोग कर रहे हैं।
यदि आप App Router का उपयोग कर रहे हैं, तो कृपया इसके बजाय इस मार्गदर्शिका को देखें।
चरण 1: एक i18n लाइब्रेरी स्थापित करें
अपने Next.js एप्लिकेशन में अंतर्राष्ट्रीयकरण लागू करने के लिए, हम पहले एक i18n लाइब्रेरी चुनेंगे। कई लोकप्रिय लाइब्रेरी हैं, जिनमें next-intl शामिल हैं। हालाँकि, इस उदाहरण में हम TacoTranslate का उपयोग करेंगे।
TacoTranslate उन्नत AI का उपयोग करके आपके स्ट्रिंग्स को किसी भी भाषा में स्वचालित रूप से अनुवाद कर देता है, और आपको JSON फ़ाइलों के थकाऊ प्रबंधन से मुक्त कर देता है।
आइए इसे अपने टर्मिनल में npm का उपयोग करके इंस्टॉल करें:
npm install tacotranslate
चरण 2: एक मुफ्त TacoTranslate खाता बनाएं
अब जब आपने मॉड्यूल इंस्टॉल कर लिया है, तो अब अपना TacoTranslate खाता, एक अनुवाद प्रोजेक्ट, और संबंधित API कीज़ बनाने का समय है। यहां एक खाता बनाएं। यह मुफ्त है, और आपको क्रेडिट कार्ड जोड़ने की आवश्यकता नहीं है।
TacoTranslate एप्लिकेशन UI के भीतर एक प्रोजेक्ट बनाएं और इसके API keys टैब पर जाएँ। एक read
कुंजी बनाएं, और एक read/write
कुंजी बनाएं। हम इन्हें पर्यावरण चर के रूप में सहेजेंगे। read
कुंजी वही है जिसे हम public
कहते हैं और read/write
कुंजी secret
होती है। उदाहरण के लिए, आप इन्हें अपने प्रोजेक्ट की रूट डायरेक्टरी में .env
फ़ाइल में जोड़ सकते हैं।
TACOTRANSLATE_PUBLIC_API_KEY=123456
TACOTRANSLATE_SECRET_API_KEY=789010
यह सुनिश्चित करें कि आप कभी भी गोपनीय read/write
API कुंजी को क्लाइंट-साइड प्रोडक्शन वातावरण में लीक न करें।
हम दो और पर्यावरण चर भी जोड़ेंगे: TACOTRANSLATE_DEFAULT_LOCALE
और TACOTRANSLATE_ORIGIN
.
TACOTRANSLATE_DEFAULT_LOCALE
: डिफ़ॉल्ट फॉलबैक लोकेल कोड। इस उदाहरण में, हम इसे अंग्रेज़ी के लिएen
पर सेट करेंगे।TACOTRANSLATE_ORIGIN
: वह “फ़ोल्डर” जहाँ आपकी स्ट्रिंग्स संग्रहीत होंगी, जैसे कि आपकी वेबसाइट का URL। Origins के बारे में अधिक पढ़ें।
TACOTRANSLATE_DEFAULT_LOCALE=en
TACOTRANSLATE_ORIGIN=your-website-url.com
चरण 3: TacoTranslate सेटअप करना
अपने एप्लिकेशन में TacoTranslate को एकीकृत करने के लिए, आपको पहले दिए गए API कीज़ का उपयोग करके एक क्लाइंट बनाना होगा। उदाहरण के लिए, /tacotranslate-client.js
नाम की एक फ़ाइल बनाएं।
const {default: createTacoTranslateClient} = require('tacotranslate');
const tacoTranslate = createTacoTranslateClient({
apiKey:
process.env.TACOTRANSLATE_SECRET_API_KEY ??
process.env.TACOTRANSLATE_PUBLIC_API_KEY ??
process.env.TACOTRANSLATE_API_KEY ??
'',
projectLocale: process.env.TACOTRANSLATE_DEFAULT_LOCALE ?? '',
});
module.exports = tacoTranslate;
हम जल्द ही TACOTRANSLATE_API_KEY
को स्वचालित रूप से परिभाषित करेंगे।
क्लाइंट को एक अलग फ़ाइल में बनाने से बाद में उसे दोबारा उपयोग करना आसान हो जाता है। अब, एक कस्टम /pages/_app.tsx
का उपयोग करते हुए, हम TacoTranslate
प्रदाता जोड़ेंगे।
import React from 'react';
import {type AppProps} from 'next/app';
import {type Origin, type Locale, type Localizations} from 'tacotranslate';
import TacoTranslate from 'tacotranslate/react';
import TacoTranslateHead from 'tacotranslate/next/head';
import tacoTranslate from '../tacotranslate-client';
type PageProperties = {
origin: Origin;
locale: Locale;
locales: Locale[];
localizations: Localizations;
};
export default function App({Component, pageProps}: AppProps<PageProperties>) {
const {origin, locale, locales, localizations} = pageProps;
return (
<TacoTranslate
client={tacoTranslate}
origin={origin}
locale={locale}
localizations={localizations}
>
<TacoTranslateHead rootUrl="https://your-website.com" locales={locales} />
<Component {...pageProps} />
</TacoTranslate>
);
}
यदि आपके पास पहले से कस्टम pageProps
और _app.tsx
हैं, तो कृपया परिभाषा को ऊपर दिए गए गुणों और कोड के साथ विस्तारित करें।
चरण 4: सर्वर साइड रेंडरिंग को लागू करना
TacoTranslate आपके अनुवादों के सर्वर-साइड रेंडरिंग की अनुमति देता है। यह उपयोगकर्ता अनुभव को बहुत बेहतर बनाता है क्योंकि अनुवादित सामग्री तुरंत दिखाई जाती है, बजाय पहले अनुवादित नहीं हुई सामग्री के चमकने के। इसके अतिरिक्त, हम क्लाइंट पर नेटवर्क अनुरोधों को छोड़ सकते हैं, क्योंकि हमारे पास पहले से ही सभी आवश्यक अनुवाद मौजूद हैं।
हम /next.config.js
को बनाकर या संशोधित करके शुरू करेंगे।
const withTacoTranslate = require('tacotranslate/next/config').default;
const tacoTranslateClient = require('./tacotranslate-client');
module.exports = async () => {
const config = {};
return withTacoTranslate(config, {
client: tacoTranslateClient,
isProduction:
process.env.TACOTRANSLATE_ENV === 'production' ||
process.env.VERCEL_ENV === 'production' ||
(!(process.env.TACOTRANSLATE_ENV || process.env.VERCEL_ENV) &&
process.env.NODE_ENV === 'production'),
});
};
अपने सेटअप के अनुसार isProduction
चेक को संशोधित करें। यदि true
है, तो TacoTranslate सार्वजनिक API कुंजी दिखाएगा। यदि हम स्थानीय, परीक्षण, या स्टेजिंग वातावरण में हैं (isProduction
is false
) तो हम नए स्ट्रिंग्स के अनुवाद के लिए सुनिश्चित करने हेतु गुप्त read/write
API कुंजी का उपयोग करेंगे।
अब तक, हमने केवल Next.js एप्लिकेशन को समर्थित भाषाओं की एक सूची के साथ सेट किया है। अगला कदम यह होगा कि हम आपके सभी पृष्ठों के लिए अनुवाद प्राप्त करें। ऐसा करने के लिए, आपकी आवश्यकताओं के अनुसार आप getTacoTranslateStaticProps
या getTacoTranslateServerSideProps
में से किसी एक का उपयोग करेंगे।
ये फ़ंक्शन तीन आर्ग्यूमेंट लेते हैं: एक Next.js Static Props Context ऑब्जेक्ट, TacoTranslate के लिए कॉन्फ़िगरेशन, और वैकल्पिक Next.js प्रॉपर्टीज़। ध्यान दें कि getTacoTranslateStaticProps
पर revalidate
डिफ़ॉल्ट रूप से 60 पर सेट है, ताकि आपके अनुवाद अद्यतित रहें।
किसी भी फ़ंक्शन को किसी पेज में उपयोग करने के लिए, मान लें कि आपके पास इस तरह की एक पेज फ़ाइल है: /pages/hello-world.tsx
.
import {Translate} from 'tacotranslate/react';
import getTacoTranslateStaticProps from 'tacotranslate/next/get-static-props';
import tacoTranslateClient from '../tacotranslate-client';
export async function getStaticProps(context) {
return getTacoTranslateStaticProps(context, {client: tacoTranslateClient});
}
export default function Page() {
return <Translate string="Hello, world!"/>;
}
अब आप Translate
कॉम्पोनेंट का उपयोग करके अपने सभी React कॉम्पोनेंट्स के भीतर स्ट्रिंग्स का अनुवाद कर सकेंगे।
import {Translate} from 'tacotranslate/react';
function Component() {
return <Translate string="Hello, world!"/>
}
चरण 5: तैनात करें और परीक्षण करें!
हम हो चुके हैं! अब आपकी React एप्लिकेशन स्वचालित रूप से अनुवादित हो जाएगी जब आप किसी Translate
कंपोनेंट में कोई भी स्ट्रिंग जोड़ेंगे। ध्यान दें कि केवल वे वातावरण जिनके पास API कुंजी पर read/write
अनुमतियाँ हैं, वे नई स्ट्रिंग्स बना पाएंगे जिन्हें अनुवादित किया जाएगा। हम अनुशंसा करते हैं कि आपके पास एक बंद और सुरक्षित स्टेजिंग वातावरण हो, जहाँ आप उस तरह की API कुंजी के साथ अपनी प्रोडक्शन एप्लिकेशन का परीक्षण कर सकें और लाइव होने से पहले नई स्ट्रिंग्स जोड़ सकें। यह किसी को भी किसी को भी आपकी गुप्त API कुंजी चुराने से रोकेगा, और संभावित रूप से नए, असंबंधित स्ट्रिंग्स जोड़कर आपके अनुवाद प्रोजेक्ट को अतिभारित करने से भी बचाएगा।
हमारे GitHub प्रोफ़ाइल पर पूरा उदाहरण ज़रूर देखें। वहाँ आपको इसका App Router का उपयोग करके करने का एक उदाहरण भी मिलेगा! यदि आपको कोई समस्या हो तो बेझिझक संपर्क करें, और हम आपकी सहायता करने में बहुत प्रसन्न होंगे।
TacoTranslate आपको अपनी React एप्लिकेशनों को 75 से अधिक भाषाओं में और उनसे स्वतः जल्दी लोकलाइज़ करने देता है। आज ही शुरू करें!