मराठी

या सखोल tsconfig.json मार्गदर्शकासह टाइपस्क्रिप्ट कॉन्फिगरेशनमध्ये प्रभुत्व मिळवा. कार्यक्षम विकासासाठी आवश्यक कंपाइलर पर्याय, प्रकल्प सेटअप आणि प्रगत कॉन्फिगरेशन्स शिका.

टाइपस्क्रिप्ट कॉन्फिगरेशन: एक सर्वसमावेशक tsconfig.json मार्गदर्शक

टाइपस्क्रिप्ट, जावास्क्रिप्टचा सुपरसेट, वेब डेव्हलपमेंटच्या डायनॅमिक जगात स्टॅटिक टायपिंग आणते. टाइपस्क्रिप्टच्या पूर्ण क्षमतेचा वापर करण्यासाठी एक सु-कॉन्फिगर केलेली tsconfig.json फाईल खूप महत्त्वाची आहे. हे मार्गदर्शक tsconfig.json चा सर्वसमावेशक आढावा देते, ज्यामध्ये आवश्यक कंपाइलर पर्याय, प्रोजेक्ट सेटअप आणि प्रगत कॉन्फिगरेशन्स समाविष्ट आहेत.

tsconfig.json काय आहे?

tsconfig.json फाईल ही एक कॉन्फिगरेशन फाईल आहे जी टाइपस्क्रिप्ट प्रोजेक्टसाठी कंपाइलर पर्याय निर्दिष्ट करते. ही टाइपस्क्रिप्ट कंपाइलरला सांगते की टाइपस्क्रिप्ट कोडचे जावास्क्रिप्टमध्ये कसे रूपांतरण करायचे. ही फाईल प्रोजेक्टची रचना परिभाषित करण्यासाठी, संकलनाचे नियम सेट करण्यासाठी आणि विकास टीममध्ये सुसंगतता सुनिश्चित करण्यासाठी आवश्यक आहे, मग ती टीम एकाच कार्यालयात स्थित असो किंवा अनेक खंडांमध्ये वितरीत असो.

tsconfig.json फाईल कशी तयार करावी

tsconfig.json फाईल तयार करण्यासाठी, टर्मिनलमध्ये तुमच्या प्रोजेक्टच्या रूट डिरेक्टरीवर जा आणि खालील कमांड चालवा:

tsc --init

ही कमांड सामान्यतः वापरल्या जाणार्‍या कंपाइलर पर्यायांसह एक मूलभूत tsconfig.json फाईल तयार करते. त्यानंतर तुम्ही तुमच्या प्रोजेक्टच्या विशिष्ट आवश्यकतांनुसार फाईल कस्टमाइझ करू शकता. एका सामान्य tsconfig.json मध्ये compilerOptions, include, आणि exclude सारखे पर्याय समाविष्ट असतील.

आवश्यक कंपाइलर पर्याय

compilerOptions विभाग हा tsconfig.json फाईलचा गाभा आहे. यात विविध पर्याय आहेत जे टाइपस्क्रिप्ट कंपाइलरच्या वर्तनावर नियंत्रण ठेवतात. येथे काही सर्वात महत्त्वाचे कंपाइलर पर्याय दिले आहेत:

target

target पर्याय व्युत्पन्न केलेल्या जावास्क्रिप्ट कोडसाठी ECMAScript लक्ष्य आवृत्ती निर्दिष्ट करतो. सामान्य मूल्यांमध्ये ES5, ES6 (ES2015), ES2016, ES2017, ES2018, ES2019, ES2020, ES2021, ES2022, ESNext यांचा समावेश आहे. ब्राउझर किंवा Node.js आवृत्त्यांसारख्या इच्छित रनटाइम वातावरणाशी सुसंगतता सुनिश्चित करण्यासाठी योग्य लक्ष्य निवडणे महत्त्वाचे आहे.

उदाहरण:

{
  "compilerOptions": {
    "target": "ES2020"
  }
}

module

module पर्याय मॉड्यूल कोड निर्मितीची शैली निर्दिष्ट करतो. सामान्य मूल्यांमध्ये CommonJS, AMD, System, UMD, ES6 (ES2015), ES2020, आणि ESNext यांचा समावेश आहे. मॉड्यूल सिस्टमची निवड लक्ष्य पर्यावरण आणि वापरलेल्या मॉड्यूल बंडलरवर अवलंबून असते (उदा., Webpack, Rollup, Parcel). Node.js साठी, CommonJS अनेकदा वापरला जातो, तर आधुनिक वेब ऍप्लिकेशन्ससाठी, मॉड्यूल बंडलरसह ES6 किंवा ESNext ला प्राधान्य दिले जाते. ESNext वापरल्याने विकासकांना सर्वात नवीन वैशिष्ट्ये आणि ऑप्टिमायझेशनचा फायदा घेता येतो, आणि अंतिम मॉड्यूल फॉरमॅट हाताळण्यासाठी बंडलरवर अवलंबून राहता येते.

उदाहरण:

{
  "compilerOptions": {
    "module": "ESNext"
  }
}

lib

lib पर्याय संकलनामध्ये समाविष्ट केल्या जाणार्‍या लायब्ररी फाइल्सची सूची निर्दिष्ट करतो. या लायब्ररी फाइल्स अंगभूत जावास्क्रिप्ट APIs आणि ब्राउझर APIs साठी प्रकार व्याख्या प्रदान करतात. सामान्य मूल्यांमध्ये ES5, ES6, ... ES2022.String आणि बरेच काही समाविष्ट आहे. योग्य लायब्ररी निवडल्याने टाइपस्क्रिप्ट कंपाइलरकडे लक्ष्य वातावरणासाठी आवश्यक प्रकार माहिती असल्याची खात्री होते. DOM लायब्ररी वापरल्याने प्रोजेक्टला ब्राउझर-विशिष्ट APIs वापरणारा कोड प्रकार त्रुटींशिवाय संकलित करण्याची परवानगी मिळते.

उदाहरण:

{
  "compilerOptions": {
    "lib": ["ES2020", "DOM"]
  }
}

allowJs

allowJs पर्याय टाइपस्क्रिप्ट कंपाइलरला टाइपस्क्रिप्ट फाइल्ससोबत जावास्क्रिप्ट फाइल्स संकलित करण्याची परवानगी देतो. विद्यमान जावास्क्रिप्ट प्रोजेक्ट्सना टाइपस्क्रिप्टमध्ये हळूहळू स्थलांतरित करण्यासाठी हे उपयुक्त आहे. हे true वर सेट केल्याने कंपाइलरला .js फाइल्सवर प्रक्रिया करण्यास सक्षम करते, ज्यामुळे प्रोजेक्टमध्ये टाइपस्क्रिप्टचा टप्प्याटप्प्याने अवलंब करता येतो.

उदाहरण:

{
  "compilerOptions": {
    "allowJs": true
  }
}

jsx

jsx पर्याय JSX सिंटॅक्स कसे हाताळावे हे निर्दिष्ट करतो. सामान्य मूल्यांमध्ये preserve, react, react-native, आणि react-jsx यांचा समावेश आहे. preserve आउटपुटमध्ये JSX सिंटॅक्स ठेवतो, तर react JSX ला React.createElement कॉल्समध्ये रूपांतरित करतो. react-jsx React 17 मध्ये सादर केलेले नवीन JSX ट्रान्सफॉर्म वापरतो, ज्यासाठी React आयात करण्याची आवश्यकता नाही. React किंवा इतर JSX-आधारित लायब्ररी वापरणाऱ्या प्रोजेक्टसाठी योग्य JSX पर्याय निवडणे महत्त्वाचे आहे.

उदाहरण:

{
  "compilerOptions": {
    "jsx": "react-jsx"
  }
}

declaration

declaration पर्याय प्रत्येक टाइपस्क्रिप्ट फाइलसाठी संबंधित .d.ts डिक्लरेशन फाइल्स तयार करतो. डिक्लरेशन फाइल्समध्ये प्रकार माहिती असते आणि इतर टाइपस्क्रिप्ट प्रोजेक्ट्सद्वारे संकलित कोड वापरण्यासाठी वापरली जाते. पुन्हा वापरण्यायोग्य लायब्ररी आणि मॉड्यूल तयार करण्यासाठी डिक्लरेशन फाइल्स तयार करणे आवश्यक आहे. या फाइल्स इतर टाइपस्क्रिप्ट प्रोजेक्ट्सना मूळ सोर्स कोड संकलित न करता लायब्ररीद्वारे उघड केलेले प्रकार आणि इंटरफेस समजून घेण्यास परवानगी देतात.

उदाहरण:

{
  "compilerOptions": {
    "declaration": true
  }
}

sourceMap

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

उदाहरण:

{
  "compilerOptions": {
    "sourceMap": true
  }
}

outDir

outDir पर्याय व्युत्पन्न केलेल्या जावास्क्रिप्ट फाइल्ससाठी आउटपुट डिरेक्टरी निर्दिष्ट करतो. हा पर्याय सोर्स कोडला संकलित कोडपासून वेगळे करून प्रोजेक्टच्या बिल्ड आउटपुटला संघटित करण्यास मदत करतो. outDir वापरल्याने बिल्ड प्रक्रिया व्यवस्थापित करणे आणि ऍप्लिकेशन तैनात करणे सोपे होते.

उदाहरण:

{
  "compilerOptions": {
    "outDir": "dist"
  }
}

rootDir

rootDir पर्याय टाइपस्क्रिप्ट प्रोजेक्टची रूट डिरेक्टरी निर्दिष्ट करतो. कंपाइलर मॉड्यूल नावे सोडवण्यासाठी या डिरेक्टरीचा आधार म्हणून वापर करतो. हा पर्याय विशेषतः जटिल डिरेक्टरी संरचना असलेल्या प्रोजेक्टसाठी महत्त्वाचा आहे. rootDir योग्यरित्या सेट केल्याने कंपाइलरला सर्व आवश्यक मॉड्यूल आणि अवलंबित्व शोधता येते याची खात्री होते.

उदाहरण:

{
  "compilerOptions": {
    "rootDir": "src"
  }
}

strict

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

उदाहरण:

{
  "compilerOptions": {
    "strict": true
  }
}

esModuleInterop

esModuleInterop पर्याय CommonJS आणि ES मॉड्यूलमध्ये आंतरकार्यक्षमता सक्षम करतो. दोन्ही प्रकारचे मॉड्यूल वापरणाऱ्या प्रोजेक्टसाठी हे महत्त्वाचे आहे. जेव्हा esModuleInterop सक्षम केले जाते, तेव्हा टाइपस्क्रिप्ट CommonJS आणि ES मॉड्यूलमधील फरक आपोआप हाताळेल, ज्यामुळे दोन प्रणालींमध्ये मॉड्यूल आयात आणि निर्यात करणे सोपे होते. हा पर्याय विशेषतः तृतीय-पक्ष लायब्ररींसह काम करताना उपयुक्त आहे जे भिन्न मॉड्यूल प्रणाली वापरू शकतात.

उदाहरण:

{
  "compilerOptions": {
    "esModuleInterop": true
  }
}

moduleResolution

moduleResolution पर्याय टाइपस्क्रिप्ट मॉड्यूल आयाती कशा सोडवते हे निर्दिष्ट करतो. सामान्य मूल्यांमध्ये Node आणि Classic यांचा समावेश आहे. Node मॉड्यूल रिझोल्यूशन स्ट्रॅटेजी डीफॉल्ट आहे आणि Node.js मॉड्यूल रिझोल्यूशन अल्गोरिदमवर आधारित आहे. Classic मॉड्यूल रिझोल्यूशन स्ट्रॅटेजी जुनी आहे आणि कमी सामान्यपणे वापरली जाते. Node मॉड्यूल रिझोल्यूशन स्ट्रॅटेजी वापरल्याने टाइपस्क्रिप्ट Node.js वातावरणात मॉड्यूल आयाती योग्यरित्या सोडवू शकते याची खात्री होते.

उदाहरण:

{
  "compilerOptions": {
    "moduleResolution": "Node"
  }
}

baseUrl आणि paths

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

उदाहरण:

{
  "compilerOptions": {
    "baseUrl": ".",
    "paths": {
      "@components/*": ["src/components/*"],
      "@utils/*": ["src/utils/*"]
    }
  }
}

Include आणि Exclude पर्याय

include आणि exclude पर्याय कोणत्या फाइल्स संकलनामध्ये समाविष्ट केल्या पाहिजेत आणि कोणत्या फाइल्स वगळल्या पाहिजेत हे निर्दिष्ट करतात. हे पर्याय फाइल नावांना जुळवण्यासाठी ग्लोब पॅटर्न वापरतात. include आणि exclude वापरल्याने तुम्हाला टाइपस्क्रिप्ट कंपाइलरद्वारे कोणत्या फाइल्सवर प्रक्रिया केली जाते हे नियंत्रित करण्याची परवानगी मिळते, ज्यामुळे बिल्ड कार्यक्षमता सुधारते आणि त्रुटी कमी होतात. संकलनामध्ये समाविष्ट केल्या जाणार्‍या फाइल्स स्पष्टपणे निर्दिष्ट करणे ही एक सर्वोत्तम पद्धत आहे.

उदाहरण:

{
  "include": ["src/**/*"],
  "exclude": ["node_modules", "dist"]
}

Extends पर्याय

extends पर्याय तुम्हाला दुसर्‍या tsconfig.json फाइलमधून कंपाइलर पर्याय वारसाने घेण्याची परवानगी देतो. अनेक प्रोजेक्ट्समध्ये सामान्य कॉन्फिगरेशन सेटिंग्ज शेअर करण्यासाठी किंवा बेस कॉन्फिगरेशन्स तयार करण्यासाठी हे उपयुक्त आहे. extends पर्याय वापरल्याने कोडचा पुनर्वापर वाढतो आणि डुप्लिकेशन कमी होते. बेस कॉन्फिगरेशन्स तयार करणे आणि त्यांना वैयक्तिक प्रोजेक्टमध्ये विस्तारित करणे ही एक सर्वोत्तम पद्धत आहे.

उदाहरण:

{
  "extends": "./tsconfig.base.json",
  "compilerOptions": {
    "jsx": "react-jsx"
  },
  "include": ["src/**/*"]
}

प्रगत कॉन्फिगरेशन्स

आवश्यक कंपाइलर पर्यायांच्या पलीकडे, tsconfig.json विशेष परिस्थितींसाठी प्रगत कॉन्फिगरेशन्सना समर्थन देते.

इन्क्रिमेंटल कंपाइलेशन

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

{
  "compilerOptions": {
    "incremental": true,
    "tsBuildInfoFile": ".tsbuildinfo"
  }
}

प्रोजेक्ट संदर्भ

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

{
  "compilerOptions": {
    "composite": true
  },
  "references": [
    { "path": "./module1" },
    { "path": "./module2" }
  ]
}

कस्टम प्रकार व्याख्या

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

// custom.d.ts
declare module 'my-library' {
  export function doSomething(x: number): string;
}

सर्वोत्तम पद्धती

सामान्य समस्यांचे निवारण

tsconfig.json कॉन्फिगर करणे कधीकधी आव्हानात्मक असू शकते. येथे काही सामान्य समस्या आणि त्यांचे निराकरण दिले आहे:

मॉड्यूल रिझोल्यूशन समस्या

तुम्हाला मॉड्यूल रिझोल्यूशन त्रुटी आढळल्यास, moduleResolution पर्याय योग्यरित्या कॉन्फिगर केला आहे आणि baseUrl आणि paths पर्याय योग्यरित्या सेट केले आहेत याची खात्री करा. paths पर्यायामध्ये निर्दिष्ट केलेले पथ योग्य आहेत याची खात्री करण्यासाठी पुन्हा तपासा. सर्व आवश्यक मॉड्यूल node_modules डिरेक्टरीमध्ये स्थापित केले आहेत याची पडताळणी करा.

प्रकार त्रुटी

प्रकार व्याख्या चुकीच्या किंवा गहाळ असल्यास प्रकार त्रुटी येऊ शकतात. तुम्ही वापरत असलेल्या सर्व लायब्ररींसाठी तुमच्याकडे योग्य प्रकार व्याख्या स्थापित केल्या आहेत याची खात्री करा. तुम्ही प्रकार व्याख्या नसलेली जावास्क्रिप्ट लायब्ररी वापरत असल्यास, कस्टम प्रकार व्याख्या तयार करण्याचा विचार करा.

संकलन त्रुटी

तुमच्या टाइपस्क्रिप्ट कोडमध्ये सिंटॅक्स त्रुटी किंवा प्रकार त्रुटी असल्यास संकलन त्रुटी येऊ शकतात. त्रुटी संदेश काळजीपूर्वक पुनरावलोकन करा आणि कोणत्याही सिंटॅक्स त्रुटी किंवा प्रकार त्रुटी दुरुस्त करा. तुमचा कोड टाइपस्क्रिप्ट कोडिंग नियमांचे पालन करतो याची खात्री करा.

निष्कर्ष

एका यशस्वी टाइपस्क्रिप्ट प्रोजेक्टसाठी एक सु-कॉन्फिगर केलेली tsconfig.json फाईल आवश्यक आहे. आवश्यक कंपाइलर पर्याय आणि प्रगत कॉन्फिगरेशन्स समजून घेऊन, तुम्ही तुमचा विकास कार्यप्रवाह ऑप्टिमाइझ करू शकता, कोड गुणवत्ता सुधारू शकता आणि लक्ष्य वातावरणाशी सुसंगतता सुनिश्चित करू शकता. tsconfig.json योग्यरित्या कॉन्फिगर करण्यात वेळ गुंतवल्यास त्रुटी कमी करून, देखरेख क्षमता सुधारून आणि बिल्ड प्रक्रिया सुव्यवस्थित करून दीर्घकाळात फायदा होईल. यामुळे अधिक कार्यक्षम आणि विश्वसनीय सॉफ्टवेअर विकास होतो. येथे प्रदान केलेली माहिती सार्वत्रिकपणे लागू होण्यासाठी डिझाइन केली आहे, आणि टाइपस्क्रिप्टसह नवीन प्रोजेक्ट सुरू करण्यासाठी एक ठोस पाया प्रदान करेल.

सर्व उपलब्ध कंपाइलर पर्यायांच्या सर्वात अद्ययावत माहिती आणि तपशीलवार स्पष्टीकरणांसाठी अधिकृत टाइपस्क्रिप्ट दस्तऐवजीकरणाचा सल्ला घेण्याचे लक्षात ठेवा. टाइपस्क्रिप्ट कॉन्फिगरेशनची गुंतागुंत समजून घेण्यासाठी टाइपस्क्रिप्ट दस्तऐवजीकरण एक मौल्यवान स्त्रोत आहे.