बूटस्ट्रैप ते वेबपैक
वेबपैक दा इस्तेमाल करदे होई अपने प्रोजेक्ट च बूटस्ट्रैप दे सीएसएस ते जावास्क्रिप्ट गी किस चाल्ली शामल करना ते बंडल करना ऐ इसदे आस्तै आधिकारिक गाइड.
सेट अप
अस नमें सिरेआ बूटस्ट्रैप कन्नै इक वेबपैक प्रोजेक्ट बना करदे आं, इसलेई अस सचमुच शुरू करने थमां पैह् ले किश पूर्व शर्तें ते अग्गें दे कदम न। इस गाइड च तुसेंगी Node.js इंस्टॉल करना ते टर्मिनल कन्नै किश परिचित होना लोड़चदा ऐ.
-
इक प्रोजेक्ट फोल्डर बनाओ ते एनपीएम सेटअप करो।
my-project
अस फोल्डर बनागे ते npm गी-y
आर्गुमेंट कन्नै इनिशियलाइज करगे तां जे एह् असेंगी सारे इंटरएक्टिव सवाल पुच्छने थमां बचाई सकै।mkdir my-project && cd my-project npm init -y
-
वेबपैक इंस्टॉल करो। अगले असेंगी अपनी वेबपैक विकास निर्भरताएं गी इंस्टॉल करने दी लोड़ ऐ:
webpack
वेबपैक दे कोर आस्तै,webpack-cli
तां जे अस टर्मिनल थमां वेबपैक कमांड चला सकचे, तेwebpack-dev-server
इस चाल्ली अस इक लोकल विकास सर्वर चला सकचे। अस--save-dev
इस गल्लै दा संकेत देने दा इस्तेमाल करदे आं जे एह् निर्भरता सिर्फ विकास आस्तै गै ऐ ते उत्पादन आस्तै नेईं ऐ ।npm i --save-dev webpack webpack-cli webpack-dev-server
-
बूटस्ट्रैप इंस्टॉल करो। हुण अस बूटस्ट्रैप इंस्टॉल करी सकने आं। अस Popper गी बी इंस्टॉल करगे की जे साढ़े ड्रॉपडाउन, पोपोवर, ते टूलटिप उंदी स्थिति आस्तै इस पर निर्भर करदे न। जेकर तुस उनें घटकें दा इस्तेमाल करने दी योजना नेईं बनांदे ओ तां तुस इत्थें पॉपर गी छड्डी सकदे ओ।
npm i --save bootstrap @popperjs/core
-
अतिरिक्त निर्भरताएं गी स्थापित करो। वेबपैक ते बूटस्ट्रैप दे अलावा, असेंगी बूटस्ट्रैप दे सीएसएस ते जेएस गी वेबपैक कन्नै ठीक ढंगै कन्नै आयात ते बंडल करने आस्तै किश होर निर्भरताएं दी लोड़ ऐ। इनें च सस्स, किश लोडर, ते ऑटोप्रिफिक्सर शामल न।
npm i --save-dev autoprefixer css-loader postcss-loader sass sass-loader style-loader
हुण जेकर असें गी सारी जरूरी निर्भरताएं गी इंस्टॉल कीता गेदा ऐ तां अस प्रोजेक्ट फाइलें गी बनाने ते बूटस्ट्रैप गी आयात करने दे कम्मै च आई सकने आं।
परियोजना संरचना
अस पैह् ले थमां गै my-project
फोल्डर बनाई लेदा ऐ ते npm गी शुरू करी चुके दा ऐ। हुण अस प्रोजेक्ट स्ट्रक्चर गी गोल करने आस्तै अपने src
ते फोल्डर बी बनागे । dist
थमां निम्नलिखित चलाओ my-project
, जां मैन्युअल रूप कन्नै हेठ दित्ते गेदे फोल्डर ते फाइल संरचना बनाओ.
mkdir {dist,src,src/js,src/scss}
touch dist/index.html src/js/main.js src/scss/styles.scss webpack.config.js
जदूं तुस पूरा करी लैंदे ओ तां तुंदा पूरा प्रोजेक्ट इस चाल्ली दिक्खना चाहिदा ऐ:
my-project/
├── dist/
│ └── index.html
├── src/
│ ├── js/
│ │ └── main.js
│ └── scss/
│ └── styles.scss
├── package-lock.json
├── package.json
└── webpack.config.js
इस बिंदु पर, सब किश सही जगह पर ऐ, पर वेबपैक कम्म नेईं करग कीजे अस webpack.config.js
अजें तगर अपना नेईं भरेआ ऐ।
वेबपैक गी कॉन्फ़िगर करो
निर्भरताएं गी इंस्टॉल करियै ते साढ़े प्रोजेक्ट फोल्डर साढ़े आस्तै कोडिंग शुरू करने आस्तै तैयार होने कन्नै, अस हून वेबपैक गी कॉन्फ़िगर करी सकने आं ते अपने प्रोजेक्ट गी लोकल रूप कन्नै चला सकने आं।
-
webpack.config.js
अपने एडिटर च खोलो । चूंकि एह् खाली ऐ, असेंगी इस च किश बॉयलरप्लेट कॉन्फ़िगरेशन जोड़ने दी लोड़ होग तां जे अस अपना सर्वर शुरू करी सकचे. कॉन्फ़िगरेशन दा एह् हिस्सा वेबपैक गी दस्सदा ऐ जे साढ़े प्रोजेक्ट दी जावास्क्रिप्ट गी दिक्खना हा, संकलित कोड गी कुत्थें आउटपुट करना ऐ (dist
), ते विकास सर्वर गी किस चाल्ली बर्ताव करना चाहिदा ऐ (dist
गर्म रिलोड कन्नै फोल्डर थमां खींचना)।const path = require('path') module.exports = { entry: './src/js/main.js', output: { filename: 'main.js', path: path.resolve(__dirname, 'dist') }, devServer: { static: path.resolve(__dirname, 'dist'), port: 8080, hot: true } }
-
अगले असी अपने
dist/index.html
. एह् HTML पृष्ठ ऐ जेह् ड़ा वेबपैक बंडल कीते गेदे सीएसएस ते जेएस दा उपयोग करने आस्तै ब्राउज़र च लोड होग जेह् ड़ा अस बाद दे चरणें च इस च जोड़गे। ऐसा करने थमां पैह् ले असेंगी इसगी रेंडर करने आस्तै किश देना होग तेoutput
पिछले चरण थमां जेएस गी शामल करना होग।<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>Bootstrap w/ Webpack</title> </head> <body> <div class="container py-4 px-3 mx-auto"> <h1>Hello, Bootstrap and Webpack!</h1> <button class="btn btn-primary">Primary button</button> </div> <script src="./main.js"></script> </body> </html>
अस इत्थें बूटस्ट्रैप स्टाइलिंग दा थोड़ा-थोड़ा हिस्सा बी शामल करा करदे आं
div class="container"
ते<button>
तां जे अस दिक्खने आं जे बूटस्ट्रैप दा सीएसएस वेबपैक आसेआ कदूं लोड होंदा ऐ। -
हुण असेंगी वेबपैक चलाने लेई इक npm स्क्रिप्ट दी लोड़ ऐ। हेठ दित्ती गेदी स्क्रिप्ट गी खोलो
package.json
ते जोड़ोstart
(तुंदे कोल पैह् ले थमां गै परीक्षण स्क्रिप्ट होनी चाहिदी)। अस इस स्क्रिप्ट दा इस्तेमाल अपने लोकल वेबपैक देव सर्वर गी शुरू करने आस्तै करगे।{ // ... "scripts": { "start": "webpack serve --mode development", "test": "echo \"Error: no test specified\" && exit 1" }, // ... }
-
ते आखरी च, अस वेबपैक शुरू करी सकने आं। अपने टर्मिनल च फोल्डर थमां
my-project
, उस नमीं जोड़ी दी npm स्क्रिप्ट चलाओ:npm start
इस गाइड दे अगले ते अंतिम भाग च, अस वेबपैक लोडर सेट करगे ते बूटस्ट्रैप दे सारे CSS ते जावास्क्रिप्ट आयात करगे.
बूटस्ट्रैप आयात करो
वेबपैक च बूटस्ट्रैप आयात करने आस्तै उनें लोडरें दी लोड़ होंदी ऐ जेह् ड़े असें पैह् ले भाग च इंस्टाल कीते हे। अस इन्हें गी npm कन्नै इंस्टाल कीता ऐ, पर हून वेबपैक गी इन्हें दा इस्तेमाल करने आस्तै कॉन्फ़िगर करने दी लोड़ ऐ.
-
में लोडर सेट करो
webpack.config.js
। तुंदी कॉन्फ़िगरेशन फाइल हून पूरी होई गेई ऐ ते निचले स्निपेट कन्नै मेल खंदा ऐ. इत्थै इक गै नमां हिस्सा ऐmodule
खंड।const path = require('path') module.exports = { entry: './src/js/main.js', output: { filename: 'main.js', path: path.resolve(__dirname, 'dist') }, devServer: { static: path.resolve(__dirname, 'dist'), port: 8080, hot: true }, module: { rules: [ { test: /\.(scss)$/, use: [ { loader: 'style-loader' }, { loader: 'css-loader' }, { loader: 'postcss-loader', options: { postcssOptions: { plugins: () => [ require('autoprefixer') ] } } }, { loader: 'sass-loader' } ] } ] } }
इत्थें इक रिकैप ऐ जे असेंगी इनें सारे लोडरें दी लोड़ कीऽ ऐ। HTML पृष्ठ दे च इक तत्व च
style-loader
CSS गी इंजेक्ट करदा ऐ , ते , दा इस्तेमाल करने च मदद करदा ऐ , ऑटोप्रिफिक्सर आस्तै जरूरी ऐ , ते असेंगी Sass दा इस्तेमाल करने दी इजाजत दिंदा ऐ ।<style>
<head>
css-loader
@import
url()
postcss-loader
sass-loader
-
हुण, आओ बूटस्ट्रैप दा सीएसएस आयात करचै।
src/scss/styles.scss
बूटस्ट्रैप दे सारे स्रोत Sass आयात करने लेई निम्नलिखित गी जोड़ो .// Import all of Bootstrap's CSS @import "~bootstrap/scss/bootstrap";
जेकर तुस चांदे ओ तां तुस साढ़ी स्टाइलशीट गी बी व्यक्तिगत तौर पर आयात करी सकदे ओ। विस्तार लेई साढ़े Sass आयात डॉक्स पढ़ो ।
-
अगले अस CSS लोड करदे आं ते बूटस्ट्रैप दी जावास्क्रिप्ट आयात करदे आं।
src/js/main.js
सीएसएस लोड करने ते बूटस्ट्रैप दे सारे जेएस आयात करने लेई निम्नलिखित गी जोड़ो . पॉपर गी बूटस्ट्रैप दे राहें स्वतः आयात कीता जाग।// Import our custom CSS import '../scss/styles.scss' // Import all of Bootstrap's JS import * as bootstrap from 'bootstrap'
बंडल आकारें गी घट्ट रखने आस्तै तुस जावास्क्रिप्ट प्लगइन्स गी बी बक्ख-बक्ख रूप कन्नै आयात करी सकदे ओ :
import Alert from 'bootstrap/js/dist/alert' // or, specify which plugins you need: import { Tooltip, Toast, Popover } from 'bootstrap'
बूटस्ट्रैप दे प्लगइन्स दा इस्तेमाल करने दे तरीकें बारै होर मती जानकारी आस्तै साढ़े जावास्क्रिप्ट डॉक्स पढ़ो .
-
ते तुसी खत्म होई गेदे ओ! 🎉 बूटस्ट्रैप दा स्रोत Sass ते JS पूरी चाल्ली लोड होने कन्नै, तुंदा लोकल विकास सर्वर हुन इस चाल्ली दिक्खना चाहिदा ऐ।
हुण तुस कुसै बी बूटस्ट्रैप घटक गी जोड़ना शुरू करी सकदे ओ जेह् ड़ा तुस इस्तेमाल करना चांह् दे ओ। अतिरिक्त कस्टम Sass गी किस चाल्ली शामल कीता जा ते बूटस्ट्रैप दे CSS ते JS दे सिर्फ उनें हिस्सें गी आयात करियै जेह् ड़े तुसेंगी लोड़चदे न , अपने बिल्ड गी अनुकूलित करने आस्तै पूरी वेबपैक उदाहरन प्रोजेक्ट दी जांच करना सुनिश्चत करो .
उत्पादन अनुकूलन करना
अपने सेटअप दे आधार उप्पर, तुस उत्पादन च प्रोजेक्ट चलाने लेई उपयोगी किश अतिरिक्त सुरक्षा ते गति अनुकूलन लागू करना चांह् दे ओ। ध्यान रक्खो जे एह् अनुकूलन वेबपैक उदाहरन प्रोजेक्ट पर लागू नेईं कीते जंदे न ते लागू करना तुंदे उप्पर ऐ.
सीएसएस कड्ढना ऐ
अस उपर कॉन्फ़िगर कीता style-loader
ऐ सुविधाजनक रूप कन्नै बंडल च CSS उत्सर्जित करदा ऐ तां जे मैन्युअल रूप कन्नै इक CSS फाइल गी लोड dist/index.html
करना जरूरी नेईं ऐ. एह् तरीका इक सख्त सामग्री सुरक्षा नीति कन्नै कम्म नेईं करी सकदा ऐ, पर, ते बड्डे बंडल आकार दे कारण एह् तुंदे एप्लिकेशन च इक अड़चन बनी सकदा ऐ.
CSS गी बक्ख करने आस्तै तां जे अस इसगी सीधे थमां लोड करी सकचे , वेबपैक प्लगइन dist/index.html
दा इस्तेमाल करो .mini-css-extract-loader
पैह् ले, प्लगइन गी इंस्टॉल करो:
npm install --save-dev mini-css-extract-plugin
फिर वेबपैक कॉन्फ़िगरेशन च प्लगइन दा इंस्टेंस करो ते इसदा इस्तेमाल करो:
--- a/webpack/webpack.config.js
+++ b/webpack/webpack.config.js
@@ -1,8 +1,10 @@
+const miniCssExtractPlugin = require('mini-css-extract-plugin')
const path = require('path')
module.exports = {
mode: 'development',
entry: './src/js/main.js',
+ plugins: [new miniCssExtractPlugin()],
output: {
filename: "main.js",
path: path.resolve(__dirname, "dist"),
@@ -18,8 +20,8 @@ module.exports = {
test: /\.(scss)$/,
use: [
{
- // Adds CSS to the DOM by injecting a `<style>` tag
- loader: 'style-loader'
+ // Extracts CSS for each JS file that includes CSS
+ loader: miniCssExtractPlugin.loader
},
{
दुबारा चलाने दे बाद npm run build
, इक नमीं फाइल dist/main.css
होग , जिस च src/js/main.js
. जेकर तुस dist/index.html
हून अपने ब्राउज़र च दिक्खदे ओ तां शैली गायब होग, जि'यां एह् हून dist/main.css
. तुस पैदा कीते गेदे CSS गी dist/index.html
इस चाल्ली शामल करी सकदे ओ:
--- a/webpack/dist/index.html
+++ b/webpack/dist/index.html
@@ -3,6 +3,7 @@
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
+ <link rel="stylesheet" href="./main.css">
<title>Bootstrap w/ Webpack</title>
</head>
<body>
एसवीजी फाइलें गी कड्ढना
data:
बूटस्ट्रैप दे सीएसएस च इनलाइन यूआरआई दे राहें एसवीजी फाइलें दे मते सारे संदर्भ शामल न । जेकर तुस अपने प्रोजेक्ट आस्तै इक सामग्री सुरक्षा नीति परिभाशत करदे ओ जेह् ड़ी data:
छवियें आस्तै URIs गी ब्लॉक करदी ऐ , तां एह् SVG फाइलें गी लोड नेईं कीता जाग. तुस वेबपैक दी संपत्ति मॉड्यूल सुविधा दा उपयोग करियै इनलाइन एसवीजी फाइलें गी कड्ढियै इस समस्या थमां दूर करी सकदे ओ.
इनलाइन SVG फाइलें गी इस चाल्ली कड्ढने आस्तै वेबपैक गी कॉन्फ़िगर करो:
--- a/webpack/webpack.config.js
+++ b/webpack/webpack.config.js
@@ -16,6 +16,14 @@ module.exports = {
},
module: {
rules: [
+ {
+ mimetype: 'image/svg+xml',
+ scheme: 'data',
+ type: 'asset/resource',
+ generator: {
+ filename: 'icons/[hash].svg'
+ }
+ },
{
test: /\.(scss)$/,
use: [
दुबारा चलाने दे बाद npm run build
, तुसें गी SVG फाइलें dist/icons
गी CSS च कड्ढी गेदी ते ठीक ढंगै कन्नै संदर्भित लब्भग.
इत्थें कोई गलत या पुरानी गल्ल दिक्खी? कृपा करियै GitHub पर इक मुद्दा खोलो . समस्या निवारन च मदद दी लोड़ ऐ ? GitHub पर सर्च करो जां इक चर्चा शुरू करो ।