/React

一个入门 React 的学习笔记

Primary LanguageJavaScript

React

这个仓库用于记录我的react使用笔记,以及和大家分享。

  1. react 语法
  2. react 路由
  3. redux
  4. react 环境搭建
  5. react 自定义组件实例
  6. react-hook

react环境搭建

如果不想这么麻烦可以使用脚手架

前言

react不像jquery一样能通过src直接使用它需要一系列的辅助工具的支持,我们在学习react之前需要初步了解 nodejs webpack 以及 babel。

另外还需要掌握 es6 jsx 函数式编程 等知识。

1、

安装nodejs

2、

新建项目文件夹 例如这个仓库下的 demos/环境搭建。

3、

安装 react、react-dom 包。

npm i react react-dom -S

4、

新建react项目入口文件 app.js 。

新建项目主页 index.html 。

新建 webpack 配置文件 webpack.config.js 。

app.js

import React from 'react'
import ReactDOM from 'react-dom'

class App extends React.Component{
    constructor(){
        super()
    }
    render(){
        return (
            <div>Hello World!</div>
        )
    }
}

ReactDOM.render(<App/>,document.getElementById('root'))

在 html 中需要一个元素来作为 react dom 树的根节点,注意最好不要使用 body 。 原因

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <div id="root"></div>
</body>
</html>

webpack.config.js

var HtmlWebpackPlugin = require('html-webpack-plugin')
var path = require('path')

module.exports = {
    entry: './app.js',
    output: {
        path: path.resolve(__dirname, 'build'),
        filename: 'bundle.js'
    },
    plugins: [
        new HtmlWebpackPlugin({
            template: './index.html'
        })
    ],
    module: {
        rules: [
            { test: /\.jsx?$/, use: [ {
                loader: 'babel-loader',
                options: {
                    presets: ['@babel/env', '@babel/react'],
                }
            } ] },
            { test: /\.css$/, use: ['style-loader', 'css-loader'] },
            { test: /\.html$/, use: ['html-loader'] },
            { test: /\.(png|jpe?g|gif|svg|mp4|webm|ogg|mp3|wav|flac|aac|woff2?|eot|ttf|otf)$/, use: [ { 
                loader: 'url-loader', 
                options: {
                    limit: 10000
                } 
            } ]}
        ]
    },
    devServer: {
        contentBase: __dirname,
        port: 8080,
        open: 'http://localhost:8080'
    }
}

注意

webpack.config.js 中增加了 bable env react html-laoder style-loader css-laoder url-loader 等。

所以我们需要把这些依赖下来下来。

下载 es6 转 es5、jsx 转 js 的工具:

npm i @babel/core babel-loader @babel/preset-env @babel/preset-react -D

下载将 css 转 js 的工具:

npm i css-loader style-loader -D

下载将 html 引入 webpack 的工具:

npm i html-loader -D

下载装载文件的工具:

npm i url-loader -D

下载装载 html 的工具: (将bundle.js自动加入html。)

npm i html-webpack-plugin -D

下载启动本地服务的工具:

sudo npm i webpack webpack-dev-server -g
npm i webpack webpack-dev-server -D

下载 webpack :

npm i webpack -D

如果电脑内已经全局和本地安装了 webpack-cli 那么不必运行以下两行。

sudo npm i webpack-cli -g
npm i webpack-cli

到这里依赖就已经装完了。

下载完别忘了 npm init 。

运行一下。

webpack-dev-server --mode development

5、

其他配置:

sass

npm i sass-loader node-sass -D

webpack.config.js

var HtmlWebpackPlugin = require('html-webpack-plugin')
var path = requre('path')

module.exports = {
    // ...
    module: {
        rules: [
            // ...
            { test: /\.css$/, use: ['style-loader', 'css-loader'] },
            { test: /\.(scss|sass)$/, use: ['style-loader', 'css-loader', 'sass-loader'] }
            // ...
        ]
    },
    // ...
}

新建 app.scss。

$green : green;
.green {
    color: $green;
}

app.js

import './app.scss' // 在app.js 引入sass

压缩 js css

var HtmlWebpackPlugin = require('html-webpack-plugin')
var UglifyJsPlugin = require('uglifyjs-webpack-plugin');

module.exports = {
    // ...
    plugins: [
        new HtmlWebpackPlugin({
            template: './index.html',
            minify: {
                removeComments: true,//清除HTML注释
                collapseWhitespace: true,//压缩HTML
                removeEmptyAttributes: true,//删除所有空格作属性值 <input id="" /> ==> <input />
                removeScriptTypeAttributes: true,//删除<script>的type="text/javascript"
                removeStyleLinkTypeAttributes: true,//删除<style>和<link>的type="text/css"
                minifyJS: true,//压缩页面JS
                minifyCSS: true//压缩页面CSS
            }
        }),
        new UglifyJsPlugin() // 压缩js
    ],
    // ...
}

抽离公共 js 单独抽取 css 等等

请查看 webpack plugin

scripts

如果觉得每次运行项目都需要输入 webpack-dev-server --mode development 太麻烦的话可以在 package.json 中的 scripts 字段下添加 cmd 命令。

package.json

{
  "scripts": {
    "dev": "webpack-dev-server --mode development"
  },
}

就可以通过 npm run dev 来运行项目啦。

react 项目 alias 配置

alias 别名 指的是在项目开发的过程中对某一个资源引用路径取别名。

为什么我们要取别名?

因为使用相对路径比较费脑子,且容易出错,为避免浪费宝贵的时间在这种没有技术含量的事情上建议使用别名来代替相对路径。

例如: 我们将 src 取名为 @src 以下写法将会变得简单

|-src // 代码源文件
| |- components // 组件 
| |  |
| |  | - charts // 图表
| |  |     |
| |  |     | - EagleEyePieChart // 目标组件

不用 alias 的话,在不用的文件中引用这个组件会有不同的相对路径,也就是有不同数目的 ../ 的相互拼接,这导致一个问题就是当你的项目结构发生改变的时候这该死的相对路径的会很烦人。

import PieCharts from '../../components/charts/EagleEyePieChart';

使用 alias 的话,我们在任何文件中引用这个组件写法都是和下面的代码一模一样。是不是很方便。

import PieCharts from '@src/components/charts/EagleEyePieChart';

下面来介绍下如何在 React 项目中配置 alias

  1. 如果你的 react 项目是用 create-react-app 生成的那么你需要 打开 react 项目的配置项 命令是 npm run eject 参考打开 webpack 配置项.

  2. 接下来找到 webpack.config.js 这个文件

  3. 找到 resolve 下的 aliasresolve.alias 中新增你要取别名的文件夹路径。

        resolve: {
        //...
        alias: {
            //...
            "@src":paths.appSrc,
        },
        // ...
        }
  4. 如果你的项目是 typescript 项目请找到 tsconfig.json 添加以下设置:

    {
    "compilerOptions": {
        "baseUrl": ".",
        "paths": {
        "@src/*":["./src/*"]
        }
    }
    }

学习 react 语法

进一步学习 react 语法