Skip to content

Latest commit

 

History

History
97 lines (66 loc) · 4.33 KB

README.md

File metadata and controls

97 lines (66 loc) · 4.33 KB

DEMO LINK

FIGMA

Project Overview

Website Name: Phone Catalog

Purpose:

To provide users with an easy-to-navigate platform for browsing and purchasing mobile devices. Technologies Used

React:

A JavaScript library for building user interfaces, React allows for the creation of reusable UI components. It helps manage the state of the application efficiently and offers a virtual DOM for optimal performance.

React Router:

A powerful library for routing in React applications, React Router enables navigation between different views without refreshing the page. It allows for the dynamic rendering of components based on the URL.

JavaScript (ES6+):

The primary programming language used for implementing the website's functionality. Features like arrow functions, destructuring, and modules are utilized to enhance code readability and maintainability.

HTML5:

Used for structuring the content of the web pages. Semantic HTML tags are employed to improve accessibility and SEO.

CSS3:

Styles the application to ensure a visually appealing layout. Flexbox and Grid are used for responsive design, making the site accessible on various devices.

Git and GitHub:

Version control system and hosting service used for tracking changes in the codebase and deploying the application to GitHub Pages.

Node.js:

A JavaScript runtime that allows you to run JavaScript on the server side. It is used during development for package management and running build scripts.

Running the Project Locally

To run the Phone Catalog project locally, follow these steps:

Prerequisites

Node.js: Ensure you have Node.js installed on your machine. The project is compatible with Node.js version 14.x

Instructions

Clone the Repository:

Open your terminal and run the following command to clone the project repository:

git clone https://github.com/stepan-r/phone-catalog.git

Navigate to the Project Directory:

Change your directory to the cloned project folder: npm install

Start the Development Server:

After the dependencies are installed, you can start the development server: npm start This will launch the application in your default web browser, usually accessible at http://localhost:3000.

Build for Production (Optional):

If you want to create a production build of the application, run: npm run build This will create a build folder containing the optimized application, which can be deployed to a web server.

Conclusion

The Phone Catalog website is a well-structured, user-friendly platform that leverages modern web technologies to provide an efficient shopping experience. The combination of React and React Router allows for a dynamic and responsive interface, making it easy for users to browse and purchase mobile phones. By following the instructions above, you can run the project locally and explore its features.

Key Features

Dynamic Routing:

Utilizes React Router to manage navigation between different pages (e.g., home, product details, cart) without full page reloads.

Responsive Design:

The website is designed to be mobile-friendly, ensuring a good user experience across various devices.

Product Listings:

Displays a catalog of phones with essential details such as images, specifications, and prices.

User Interaction:

Allows users to click on products to view more details, enhancing the shopping experience.

Development Process

Setting Up the Project:

Created a new React application using Create React App. Installed necessary dependencies, including React Router for routing capabilities.

Building Components:

Developed reusable components for the header, footer, product listings, and individual product details. Implemented state management to handle user interactions and data flow.

Implementing Routing:

Configured routes using React Router to define paths for different views (e.g., home page, product details). Used components for navigation between pages.

Styling the Application:

Applied CSS styles to enhance the visual appeal and ensure a consistent look and feel across the site.

Testing and Deployment:

Conducted thorough testing to ensure all features functioned correctly. Deployed the application using GitHub Pages for public access.