From 3a50eceef0d2f3987f7ba70a142dd7dc3fca200a Mon Sep 17 00:00:00 2001 From: cybernoob2 Date: Sat, 6 Sep 2025 13:19:35 +0300 Subject: [PATCH] docs: add React folder with setup and patterns guides --- docs/React/images/framework.png | Bin 0 -> 18831 bytes docs/React/images/project-name.png | Bin 0 -> 4757 bytes docs/React/images/variant.png | Bin 0 -> 19687 bytes docs/React/setup.md | 74 +++++++++++++++++++++++++++++ 4 files changed, 74 insertions(+) create mode 100644 docs/React/images/framework.png create mode 100644 docs/React/images/project-name.png create mode 100644 docs/React/images/variant.png diff --git a/docs/React/images/framework.png b/docs/React/images/framework.png new file mode 100644 index 0000000000000000000000000000000000000000..47cefc7d866617d3a053b1095c7421d3f2df755d GIT binary patch literal 18831 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 X#f=vo_m6Xad++n?=lsrd&VGK+ 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 OgdA)^7hl?V-}?s_x8YO( literal 0 HcmV?d00001 diff --git a/docs/React/images/variant.png b/docs/React/images/variant.png new file mode 100644 index 0000000000000000000000000000000000000000..282c24119f4fc92d70dfe6ff4bbc35aec1dfa90e GIT binary patch literal 19687 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 Vx9=YL2|S#P!PC{xWt~$(69ABz8k_(C literal 0 HcmV?d00001 diff --git a/docs/React/setup.md b/docs/React/setup.md index e69de29..4ae3e36 100644 --- a/docs/React/setup.md +++ b/docs/React/setup.md @@ -0,0 +1,74 @@ +# Setting Up a React Environment + +In this guide, we’ll set up a React project using **Vite** using four easy steps. + +--- + +## Step 1: Check if Node.js is Installed + +Open your terminal and type: + +```bash +node -v +``` +If Node.js is installed, you’ll see a version number +```bash +v23.8.0 +``` + +If not, download and install [Node official website](https://nodejs.org/en/download/). + +💡 Installing Node.js also gives you npm (Node Package Manager), which we’ll use later. + +## Step 2: Create a Vite Project +A development server is like a playground where we build and test our React app. +We’ll use Vite for this. + +Run the following command in your terminal: + +```bash +npm create vite@latest +``` +## Step 3: Configure Vite +Vite will ask you a few questions: + +Project Name → type a name for your project folder. +![Project name](./images/project-name.png) + + +Framework → select React. +![Selecting framework](./images/framework.png) + +Variant → select JavaScript. +![Selecting variant](./images/variant.png) +:::tip NOTE +There are two Javascript variants, but in our project we will use plain Javascript. +::: + +## Step 4: Start the React Environment +Move into your project folder: + +```bash +cd my-react-app +``` +Install the required dependencies: + +```bash +npm install +``` + +Then start the development server: + +```bash +npm run dev +``` +If successful, you’ll see something like: +```bash + VITE v7.1.4 ready in 760 ms + + ➜ Local: http://localhost:5173/ + ➜ Network: use --host to expose + ➜ press h + enter to show help +``` + +Open the Local URL in your browser to view your React app 🎉. \ No newline at end of file