Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/billimarie/simple-react-tailwind-tutorial
Create a simple, multi-page website that watches your CSS changes & refreshes your app, accordingly.
https://github.com/billimarie/simple-react-tailwind-tutorial
postcss react react-js react-tutorial tailwind-css tailwindcss tutorial
Last synced: 2 months ago
JSON representation
Create a simple, multi-page website that watches your CSS changes & refreshes your app, accordingly.
- Host: GitHub
- URL: https://github.com/billimarie/simple-react-tailwind-tutorial
- Owner: billimarie
- License: mit
- Created: 2019-11-05T21:53:51.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-05T00:39:17.000Z (about 2 years ago)
- Last Synced: 2024-10-29T23:07:43.643Z (3 months ago)
- Topics: postcss, react, react-js, react-tutorial, tailwind-css, tailwindcss, tutorial
- Language: CSS
- Homepage: https://medium.com/clocktwine/creating-a-simple-website-using-react-tailwind-css-postcss-6bbc419ded0c
- Size: 1.71 MB
- Stars: 9
- Watchers: 3
- Forks: 6
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# React Tutorials
> Updated: November 11th 2019## Table of Contents
1. [Tutorial 1: A Simple Website with React, Tailwind CSS, & PostCSS](#tutorial-1)
1. [Tutorial 2: Adding CSS Transitions](#tutorial-2)# Tutorial 1
Create a simple, multi-page website that watches your CSS changes & refreshes your app, accordingly.
To view the Medium.com article: [Creating A Simple Website with React, Tailwind CSS, & PostCSS](https://medium.com/clocktwine/creating-a-simple-website-using-react-tailwind-css-postcss-6bbc419ded0c)
## What You Need
- Terminal / Command Line
- IDE (I recommend [Atom](https://github.com/atom/atom))### Versions
- Node: 8.11.3+
- npm: 6.12.1+## Getting Started
### 1. Initialize your React app using `create-react-app`:
```
$ npx create-react-app react-tailwind-site
```### 2. Change directories into the app & install `react-router-dom` (for links), `tailwindcss` (for Tailwind CSS), `autoprefixer`, & `postcss-cli` (to watch & reload CSS updates):
```
$ cd react-tailwind-site
$ npm install react-router-dom tailwindcss autoprefixer postcss-cli
```### 3. Test it out:
```
$ npm run start
```
A new window should open up (`localhost:3000`) & display the standard new React App screen.(Having trouble? See [Troubleshooting](#troubleshooting)).
## Setting Up Tailwind
### 1. Initialize Tailwind & PostCSS:
```
$ npx tailwind init tailwind.config.js
```### 2. Create Tailwind.css:
```
$ cd src ; mkdir css ; cd css ; touch tailwind.css // Linux
$ cd src & mkdir css & cd css & touch tailwind.css // Windows
```### 3. Add to `src/css/tailwind.css`:
```
/* Init Tailwind */
@tailwind base;@tailwind components;
@tailwind utilities;
/* Custom CSS */
```## Connecting Tailwind & React
### 1. Modify your `package.json` with these updated scripts:
```
"scripts": {
"build:css": "postcss src/css/tailwind.css -o src/index.css",
"watch:css": "postcss src/css/tailwind.css -o src/index.css -w",
"start": "npm watch:css & react-scripts start",
"build": "npm run build:css && react-scripts build",
"test": "react-scripts test --env=jsdom",
"eject": "react-scripts eject"
}
```### 2. Modify `App.js`:
```
import './css/tailwind.css'; /* Replacing App.css */
```### 3. Modify `index.js`:
```
import './index.css'; /* Replacing App.css */
```### 4. Let's restart the app!
```
$ npm run start
```You should see an updated `localhost:3000` page.
To test that it's watching your CSS changes, go back to `src/css/tailwind.css` & add a new style under "Custom CSS." Your app should refresh with the changes automatically:
![react-tailwind-watching-loop](https://user-images.githubusercontent.com/6895471/68322467-44e2a100-0078-11ea-811e-13f8456cdf5f.gif)
## Creating Components
### 1. Create a folder called "Components." It should be in your source files (`/src/components/`)
```
$ mkdir components
```### 2. To start off, let's build a header.
```
$ cd src/components ; touch Header.js // Linux
$ cd src/components & touch Header.js // Windows
```### 3. In Header.js:
```
import React from 'react';
import {
BrowserRouter as Router,
Switch,
Route,
Link } from 'react-router-dom';const Header = () => (
Title Goes Here
Home
About
Contact
Login
);
export default Header;
```### 4. Go to `App.js` and add the following imports
```
import {
BrowserRouter as Router,
Switch,
Route,
Link
} from 'react-router-dom';
import Header from './components/Header.js';
```Scroll down and replace the content React automatically generated with the following:
```
const App = () => (
);
export default App;
```### 5. Now that we've made the universal header, let's create the pages for Home, About, & Contact:
```
$ touch Home.js About.js Contact.js
```Open `Home.js` add the following:
```
import React from 'react';const Home = () => (
Home
);export default Home;
```You can reuse this code for your `About.js` and `Contact.js` pages.
### 6. Again, back to `App.js` to import your new components:
```
import Home from './components/Home.js';
import About from './components/About.js';
import Contact from './components/Contact.js';
```Scroll down to modify:
```
```
### 7. Modify `index.js` to activate the router:
```
import { BrowserRouter } from 'react-router-dom';ReactDOM.render(, document.getElementById('root'));
```### 8. You're all set! Restart the app to see your new changes.
```
$ npm run start
```You should be able to see the new header, and click on each navigation item to take you to a new page:
![react-tailwind-links](https://user-images.githubusercontent.com/6895471/68329481-27b4cf00-0086-11ea-93ee-580fcef18c6e.gif)
## Complete!
If you get stuck or have any questions, feel free to send me a message. I'd love to see what you create with this; submit a pull request with your screenshot or link to be added to this GitHub repo.
## Troubleshooting
- If you receive an error about ServiceWorker.js, go to `index.js` and comment it out. (You can also delete the file itself under `src/serviceWorker.js`.)
- Additionally, if you're running Windows, make sure system32 has been added to your PATH (see: [this GitHub issue](https://medium.com/r/?url=https%3A%2F%2Fgithub.com%2Ffacebook%2Fcreate-react-app%2Fissues%2F7061)).([Back to Top](#react-tutorials))
# Tutorial 2
Adding CSS Transitions.
## Getting Started
### 1. Add `React Transition Group`:
```
$ npm install react-transition-group --save-dev
```### 2. Import in your chosen view (I picked `Home.js`):
```
import { CSSTransition } from 'react-transition-group';
```### 3. Declare new consts:
```
const [showVertical, setShowVertical] = useState(true),
[showHorizontal, setShowHorizontal] = useState(false);
```