या सखोल 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;
}
सर्वोत्तम पद्धती
- स्ट्रिक्ट मोड वापरा: वर्धित प्रकार तपासणीसाठी
strict
पर्याय सक्षम करा. - लक्ष्य निर्दिष्ट करा: तुमच्या रनटाइम वातावरणासाठी योग्य
target
आवृत्ती निवडा. - आउटपुट संघटित करा: संकलित कोडपासून सोर्स कोड वेगळे करण्यासाठी
outDir
वापरा. - अवलंबित्व व्यवस्थापित करा: कोणत्या फाइल्स संकलित केल्या जातात हे नियंत्रित करण्यासाठी
include
आणिexclude
वापरा. - Extends चा फायदा घ्या:
extends
पर्यायासह सामान्य कॉन्फिगरेशन सेटिंग्ज शेअर करा. - व्हर्जन कंट्रोलमध्ये कॉन्फिगरेशन तपासा: विकासक वातावरण आणि CI/CD पाइपलाइनमध्ये सुसंगतता राखण्यासाठी `tsconfig.json` गिटमध्ये कमिट करा.
सामान्य समस्यांचे निवारण
tsconfig.json
कॉन्फिगर करणे कधीकधी आव्हानात्मक असू शकते. येथे काही सामान्य समस्या आणि त्यांचे निराकरण दिले आहे:
मॉड्यूल रिझोल्यूशन समस्या
तुम्हाला मॉड्यूल रिझोल्यूशन त्रुटी आढळल्यास, moduleResolution
पर्याय योग्यरित्या कॉन्फिगर केला आहे आणि baseUrl
आणि paths
पर्याय योग्यरित्या सेट केले आहेत याची खात्री करा. paths
पर्यायामध्ये निर्दिष्ट केलेले पथ योग्य आहेत याची खात्री करण्यासाठी पुन्हा तपासा. सर्व आवश्यक मॉड्यूल node_modules
डिरेक्टरीमध्ये स्थापित केले आहेत याची पडताळणी करा.
प्रकार त्रुटी
प्रकार व्याख्या चुकीच्या किंवा गहाळ असल्यास प्रकार त्रुटी येऊ शकतात. तुम्ही वापरत असलेल्या सर्व लायब्ररींसाठी तुमच्याकडे योग्य प्रकार व्याख्या स्थापित केल्या आहेत याची खात्री करा. तुम्ही प्रकार व्याख्या नसलेली जावास्क्रिप्ट लायब्ररी वापरत असल्यास, कस्टम प्रकार व्याख्या तयार करण्याचा विचार करा.
संकलन त्रुटी
तुमच्या टाइपस्क्रिप्ट कोडमध्ये सिंटॅक्स त्रुटी किंवा प्रकार त्रुटी असल्यास संकलन त्रुटी येऊ शकतात. त्रुटी संदेश काळजीपूर्वक पुनरावलोकन करा आणि कोणत्याही सिंटॅक्स त्रुटी किंवा प्रकार त्रुटी दुरुस्त करा. तुमचा कोड टाइपस्क्रिप्ट कोडिंग नियमांचे पालन करतो याची खात्री करा.
निष्कर्ष
एका यशस्वी टाइपस्क्रिप्ट प्रोजेक्टसाठी एक सु-कॉन्फिगर केलेली tsconfig.json
फाईल आवश्यक आहे. आवश्यक कंपाइलर पर्याय आणि प्रगत कॉन्फिगरेशन्स समजून घेऊन, तुम्ही तुमचा विकास कार्यप्रवाह ऑप्टिमाइझ करू शकता, कोड गुणवत्ता सुधारू शकता आणि लक्ष्य वातावरणाशी सुसंगतता सुनिश्चित करू शकता. tsconfig.json
योग्यरित्या कॉन्फिगर करण्यात वेळ गुंतवल्यास त्रुटी कमी करून, देखरेख क्षमता सुधारून आणि बिल्ड प्रक्रिया सुव्यवस्थित करून दीर्घकाळात फायदा होईल. यामुळे अधिक कार्यक्षम आणि विश्वसनीय सॉफ्टवेअर विकास होतो. येथे प्रदान केलेली माहिती सार्वत्रिकपणे लागू होण्यासाठी डिझाइन केली आहे, आणि टाइपस्क्रिप्टसह नवीन प्रोजेक्ट सुरू करण्यासाठी एक ठोस पाया प्रदान करेल.
सर्व उपलब्ध कंपाइलर पर्यायांच्या सर्वात अद्ययावत माहिती आणि तपशीलवार स्पष्टीकरणांसाठी अधिकृत टाइपस्क्रिप्ट दस्तऐवजीकरणाचा सल्ला घेण्याचे लक्षात ठेवा. टाइपस्क्रिप्ट कॉन्फिगरेशनची गुंतागुंत समजून घेण्यासाठी टाइपस्क्रिप्ट दस्तऐवजीकरण एक मौल्यवान स्त्रोत आहे.