Comment créer votre site Web de portefeuille en utilisant React.js

Après que mes amis aient annulé nos projets de week-end, je cherchais quelque chose pour tuer le temps. J'ai finalement mis au point un plan pour créer un site Web de portefeuille après avoir parcouru ma longue liste de `` Wish-To-Do '' en attente.des choses.

De nombreuses heures de recherche de technologies et de modèles plus tard, j'ai fini par créer ce site Web à l'aide de React.js et le déployer à l'aide de pages Github. Vous pouvez trouver le code du site Web ici (cela s'appelle techniquement une « application Web », mais pour cet article, je vais y faire référence comme un «site Web»… j'espère que ça va).

Ce que tu vas apprendre

  • Quelques concepts de base de React.js
  • Comment utiliser create-react-app à partir d'un site Web HTML
  • Comment déployer votre site Web de portefeuille à l'aide de `` pages Github ''

Quelques concepts que vous devez connaître avant de commencer.

Remarque - n'hésitez pas à ignorer cette partie si vous êtes déjà familiarisé avec les concepts de base de React.js et des composants React.

T les points fourniront une es idée de base du React monde. Je vous recommande vivement d'étudier davantage React à partir de la documentation et de vous familiariser avec l'aide de freeCodeCamp.

Qu'est-ce que React.js>

Pour l'instant, il suffit de savoir que React.js est la bibliothèque JavaScript utilisée pour construire des composants d'interface utilisateur. Il a été créé par les ingénieurs de Facebook et de nos jours, il fait vibrer le monde JavaScript.

Qu'est-ce qu'un composant React>

React vous permet de définir des composants comme une classe ou une fonction. Vous pouvez fournir des entrées facultatives aux composants appelés « accessoires ».

Les composants vous permettent de diviser l'interface utilisateur en sections indépendantes telles que l'en-tête, le pied de page et le corps. Chaque composant fonctionnera indépendamment afin que chaque composant individuel puisse être rendu indépendamment dans le ReactDOM sans affecter la page entière.

Il est également livré avec des `` méthodes de cycle de vie '' qui vous permettent de définir des morceaux de code que vous souhaitez exécuter en fonction de l'état du composant comme le montage, le rendu, la mise à jour et le démontage.

Les composants React ont leurs propres compromis. Par exemple, nous pouvons réutiliser un composant en l'exportant vers d'autres composants, mais il est parfois difficile de gérer plusieurs composants qui parlent et déclenchent des rendus l'un pour l'autre.

voici à quoi ressemblerait un composant!

import React, { Component } from 'react' export default class Component-name extends Component { render() { return ( {these code will be rendered into the DOM} ) } }

Qu'est-ce que les pages GitHub>

Avec les pages GitHub, vous pouvez facilement déployer votre site à l'aide de GitHub gratuitement et sans avoir à configurer d'infrastructure. Ils ont fourni des modules pour que vous n'ayez pas à vous soucier de beaucoup de choses. Si vous restez jusqu'à la fin, vous verrez que cela fonctionne comme MAGIC!

Avant de continuer, assurez-vous de ...

Décidez du contenu que vous souhaitez afficher sur votre site Web

Consultez votre dernier CV une fois (si vous n'en avez pas, créez-en un maintenant et reportez ce projet au week-end prochain?). Cela vous aidera à avoir une idée claire du type d'informations que vous souhaitez mettre sur le site Web de votre portfolio.

Trouvez l'inspiration

Parcourez les centaines de modèles de sites Web de portfolio gratuits sur le Web, voyez comment et ce que vous pouvez en utiliser - prenez un stylo et du papier et esquissez un schéma approximatif pour avoir une idée de ce à quoi ressemblera votre site Web. J'utiliserai ce modèle pour démontrer.

Rassemblez de superbes photos de vous

Bien sûr, vous ne voulez pas mal paraître sur votre propre site Web de portefeuille. Alors fouillez dans vos archives de photos pour trouver les photos parfaites pour votre site Web.

Connectez-vous à votre playlist préférée

La légende veut que les bonnes choses ne viennent qu'avec de la bonne musique… et vous ne voulez certainement pas manquer de grandes choses.

Sautons dans la partie bâtiment

Dans les sections suivantes, je décrirai les étapes de création de l'application de portefeuille, mais vous n'êtes pas obligé de suivre le même code que j'utilise. Concentrez-vous sur l'apprentissage des concepts et faites preuve de créativité! Les lectures complémentaires ont été divisées en trois sections.

  1. Configuration de l'application React
  2. Décomposition de la page HTML en composants React
  3. Déployer votre application sur les pages Github

Configurer React-app

Nous utiliserons create-react-app- un module fourni par Facebook - qui nous aide à créer des applications React.js avec facilité et sans se soucier des outils de construction.

  • Accédez à la console et exécutez npm install create-react-apppour installer ce module via npm (assurez-vous que vous l'avez installé npmavant de l'utiliser - suivez ce lien pour plus d'informations).
  • Maintenant, exécutez npm create-react-app ${project-name}ce qui récupérera les scripts de construction et créera une structure de fichier qui ressemblera à ceci.
my-portfolio-app ├── README.md (description of the project for GitHUb) ├── node_modules (stores all dependent modules for the project) ├── package.json (stores all meta information of the prokect like dependencies,version,revisions etc.) ├── .gitignore (files declared here will be ignored while uploading to GitHub like node_modules ├── public (here you will store all images,JS,CSS files) │ ├── favicon.ico │ ├── index.html │ └── manifest.json └── src (our main code for app lies here) ├── {create component folder here} ├── App.css ├── App.js ├── App.test.js ├── index.css ├── index.js ├── logo.svg └── serviceWorker.js

Create a components folder under the src directory. This is where we will store our components in the future.

  • Copy all the images, fonts, HTML and CSS files from the HTML template you decided to work with into the public folder.

Now your project directory should look like this.

  • Run the npm install command which will install dependent modules under node_module directory.
  • If you’ve got it right up until now, then running the npm start command will start the React app on the localhost. Go to //localhost:3000and you should be able to see the starter page of the React-app.

Breaking-down the HTML page into React components..

Remember the component folder which we created under src directory in the previous step, now we will break down the HTML template page into components and combine these components to make our React-app.

  • First, you need to identify which components you can create from the monolithic HTML file — like header, footer and contact me. You need to be a little creative here!!
  • Look for tags like section/div which aren’t nested into some other section/div. These should contain code about that particular section of the page which is independent of other sections. Try looking into my GitHub Repo to get a better idea about this one.

    Hint: Use the ‘inspect element’ tool to play around with the code and take notice of the effect of changes within the browser.

  • These pieces of HTML code will be used in the render() method of the component. The render() method will return this code whenever a component gets rendered into the ReactDOM. Take a look at the code blocks given below for reference.
  • Hi!

    I'm Jackson

    100% html5 bootstrap templates Made by colorlib.com

    Download CV

  • I am

    a Designer

    100% html5 bootstrap templates Made by colorlib.com

    View Portfolio

import React, { Component } from 'react' export default class Home extends Component { render() { return ( 
  • Hi!

    I'm Jackson

    100% html5 bootstrap templates Made by colorlib.com

    Download CV

  • I am

    a Designer

    100% html5 bootstrap templates Made by colorlib.com

    View Portfolio

) } }

Hint: If things are getting confusing on the react side — try focusing on the concept of ‘how to identify wanna be components from the HTML codebase’. After getting comfortable with React, implementation will be a piece of cake.

Did you notice that there are some changes in the HTML code? class became className. These changes are required because React doesn’t support HTML ? — they have come up with their own HTML-like JS syntax which is called JSX . So, we need to change some parts of the HTML code to make it JSX.

I bumped into this HTML to JSX converter during this project, which converts HTML code into JSX for you ?. I highly recommend using this rather than changing your code manually.

After some time, you should come up with some different components. Now the EndGame is near!! Combine these different components under one App.js component (YES!! You can render one component from another component!) and your portfolio app will be ready.

import React, { Component } from 'react'; import './App.css'; import Sidebar from './components/sidebar' import Introduction from './components/introduction' import About from './components/about' import Projects from './components/projects' import Blog from './components/blog' import Timeline from './components/timeline' class App extends Component { render() { return ( ); } } export default App;

Notice in the above code that we need to first import the components in order to use them in the render() section. And we can use the components just by adding or just tag in the render method.

  • Run npm start from your terminal and you should be able to see the changes reflected in the website. You don’t need to run this command again if you have made more changes in the code, it will be reflected automatically when you save those changes. You can do some lightning fast development thanks to the hot reload feature.
  • Play around with the HTML and CSS to change the content according to your resume and make your portfolio even cooler by changing the content, trying out different fonts, changing the colours and adding photos of your choice.

Deploy React-app to Github pages

Okay, so you survived until this point… take a moment to appreciate your hard work. But you still need to complete your deployment so that you can share your cool work with your friends who ditched those weekend plans.

  • First, you need to install the npm library of Github pages. To install, run this command npm install gh-pages on your terminal.

Now, you need to make the following changes in your manifest.json file:

  • Add the homepage field — value will be in the following format — //{github_id}.github.io/{github_repo}
  • Add predeploy and deploy fields under scripts

Now your manifest.json should look like this:

{ "name": "portfolio-app", "version": "0.1.0", "private": true, "homepage": "//Dhruv34788.github.io/me", "dependencies": { "gh-pages": "^2.0.1", "react": "^16.8.3", "react-dom": "^16.8.3", "react-scripts": "2.1.5", "yarn": "^1.13.0"}, "scripts": { "start": "react-scripts start", "build": "react-scripts build", "predeploy": "yarn run build", "deploy": "gh-pages -d build", "test": "react-scripts test", "eject": "react-scripts eject"}, "eslintConfig": { "extends": "react-app"}, "browserslist": [ ">0.2%", "not dead", "not ie <= 11", "not op_mini all" ] }

Now go to the terminal, run npm run deploy and wait for the magic!! Your app will be deployed after the deployment scripts execute successfully. Verify whether your app has deployed or not by visiting the link you provided in the homepage field.

Caution: Please be careful when deploying anything onto the web. Perform safety checks like removing internal links, passwords, or anything that you don’t want to be there in the hands of smart people out there.

If you are going to make changes often...

Original text


Note —  You need to perform the deployment stage every time you change something and if you are making changes in the codebase - guess what whose going to get bored soon !!  ( No worries I got your back :P)

You can automate the deployment process using Travis-CI (automation tool), so that if you commit anything into master branch – the deployment steps will be triggered and new site will be automatically available. Follow this article for that.

//www.freecodecamp.org/news/learn-how-to-automate-deployment-on-github-pages-with-travis-ci/

Homework for you ..

Congratulations! You have finally created and deployed your portfolio app. If you are interested, then you can add these features to your website

  • Blog feature: create your own blog using Node.js and a NoSQL database like MongoDB and merge it into this portfolio website.
  • Gallery: add a section to the page where you can show the screenplay of the recent photos from your social media websites.
  • Twitter Feed: add a section showing recent tweets by you.
  • Random Quote: add a section showing some random motivational quotes.

If you implement any of these features, share your work with me. I would be more than happy to help ? ( if I can ?)

Wrapping up ..

I would like to take a moment to acknowledge the work of the people who gave me the inspiration and knowledge to complete this article.

  • Quincy Larson, Sahat Yalkabov & community: For creating freeCodeCamp — the platform where you can learn and gain knowledge about almost everything related to web technologies; using hands-on tutorials and all without paying fees. ?
  • Colorlib: for providing state of the art templates which were a huge inspiration for my portfolio website. ?
  • Daniel Lo Nigro & community: for creating HTML to JSX Compiler, which turned out to be handy while converting HTML blocks into JSX code. ?
  • My dearest friends: who helped me in correcting my mistakes.
  • YOU: for sticking around, I hope you had a productive time. Keep exploring and building amazing things!