Maison > interface Web > js tutoriel > Que devez-vous savoir sur le développement de projets React ? Questions spécifiques au développement de projets React (avec exemples)

Que devez-vous savoir sur le développement de projets React ? Questions spécifiques au développement de projets React (avec exemples)

寻∝梦
Libérer: 2018-09-11 11:16:30
original
2464 Les gens l'ont consulté

Cet article parle principalement de ce à quoi vous devez prêter attention lors du développement de projets React. Si vous voulez savoir, cliquez dessus et lisons cet article ensemble maintenant

.

对react项目开发,我大概对它的知识点进行了分类,主要由以下几个部分组成。
Copier après la connexion
Copier après la connexion

Méthode d'écriture de base

Méthode d'écriture de la page d'entrée

import React,{ Component } from 'react';import { render } from 'react-dom';import Main from './components/Main';

render(<Main />,document.getElementById(&#39;app&#39;));
Copier après la connexion
Copier après la connexion

Méthode d'écriture du composant

import React,{ Component } from &#39;react&#39;;
export default class Main extends Component{
    render(){        return (
            <p>
                组件
            </p>
        )
    }
}
Copier après la connexion

Valeur de passage du composant

Le composant parent est transmis au composant enfant

父组件传给子组件靠props
Copier après la connexion
Copier après la connexion
import React,{ Component } from &#39;react&#39;;
import { render } from &#39;react-dom&#39;;class Main extends Component{
    render(){        return (
            <p>
                <Child  title="我是父组件"/>
            </p>
        )
    }
}class Child extends Component{
    render(){        return(
            <h2>{this.props.title}</h2>
        )
    }
}
render(<Main />,document.getElementById(&#39;app&#39;));
Copier après la connexion
Copier après la connexion

Le composant enfant est transmis au composant parent

子组件传给父组件靠事件
子组件传递给父组件的过程描述,父组件传递给子组件一个函数,子组件执行这个函数,然后把子组件自己的值可以通过穿参的方式传递进去。然后父组件接受到这个值,进行相应的操作。
Copier après la connexion
Copier après la connexion
import React,{ Component } from &#39;react&#39;;
import { render } from &#39;react-dom&#39;;class Main extends Component{
    constructor(props){        super(props);        this.state = {
            value:&#39;init value&#39;
        }
    }
    render(){        return (
            <p>
                <p>{this.state.value}</p>
                <Child  onClick={(value)=>{this.setState({value:value})}}/>
            </p>
        )
    }
}class Child extends Component{
    render(){        return(
            <button onClick={()=>this.props.onClick("子组件的值")}>点击传值</button>
        )
    }
}
render(<Main />,document.getElementById(&#39;app&#39;));
Copier après la connexion
Copier après la connexion

webpack

webpack的配置一般分为这么几个部分,entry、output、plugin、devServer、module等。

entry告诉webpack入口在哪。
output告诉webpack将来把文件打包到哪。
plugin代表一些其他的操作,如打开浏览器、文件压缩等处理。
devServer代表开发的时候启动一个本地服务器
module代表各种loader用来解析你的代码。
Copier après la connexion
Copier après la connexion

Un fichier de configuration Webpack courant est le suivant :

var webpack = require(&#39;webpack&#39;);module.exports = {    entry:"./src/index.js",    output:{        path:&#39;public&#39;,        filename:&#39;bundle.js&#39;
    },    devServer:{        historyApiFallback:true,        hot:true,        inline:true
    },    plugins:[        new webpack.DefinePlugin({            &#39;process.env.NODE.ENV&#39;: "development"
        }),        new webpack.HotModuleReplacementPlugin(),        new OpenBrowserPlugin({            url: &#39;http://localhost:8080&#39;
        })
    ],    module:{        loaders:[{            test:/\.js[x]?$/,            exclude:/node_modules/,            loader:&#39;babel-loader&#39;,            query:{                presets:[&#39;es2015&#39;,&#39;react&#39;,&#39;stage-1&#39;]
            }
        },{            test:/\.css$/,            loaders:[&#39;style&#39;,css]
        },{            test:/\.(png|jpg)$/,            loader:"url-loader"
        }]
    }
}
Copier après la connexion
Copier après la connexion

partie es6

En réaction, la syntaxe es6 en général nécessite quelques connaissances. Pour réagir, certaines méthodes d'utilisation et d'écriture de base d'es6 sont répertoriées ici.

importer et exporter

l'importation introduit quelque chose

import webpack from &#39;webpack&#39;;import React from &#39;react&#39;;import { Component } from &#39;react&#39;;
Copier après la connexion
Copier après la connexion

La variable introduite à l'aide de "{}" est la variable du même nom qui doit exister dans ce fichier.
Les variables introduites sans "{}" sont les variables lancées par défaut d'exportation dans ce fichier, et les noms de variables peuvent être différents.

l'export lance quelque chose.

function a(){    console.log(1);
}let b = 1;export a;export b;export default a;
Copier après la connexion
Copier après la connexion

L'exportation peut être lancée plusieurs fois et utilisée plusieurs fois.
Une seule valeur par défaut d'exportation peut être utilisée, ce qui signifie qu'elle sera lancée par défaut.

class et extends

L'essence de la classe est un mot-clé qui déclare une classe. Sa signification d'existence est la même que var, let, const, function, etc.
Utilisation :

class Main{}
Copier après la connexion
Copier après la connexion

extends représente l'héritage, utilisation :

class Main extends Component{}
Copier après la connexion
Copier après la connexion

constructor représente le constructeur, super hérite des propriétés et des méthodes de la classe parent.

class Main extends Component{
    constructor(props){        super(props)
    }
}
Copier après la connexion
Copier après la connexion

Fonction de cycle de vie

Fonction de cycle de vie de base

Divisée en trois états

  • Montage

  • Mise à jour

  • Démontage


  1. Étape de montage – généralement à cette étape de life La fonction périodique ne sera exécutée qu'une seule fois
    constructor()
    componentWillMount()
    componentDidMount()
    render()

  2. La phase de mise à jour – sera exécuté plusieurs fois
    componentWillReceiveProps()
    shouldComponentUpdate()
    render()
    componentDidUpdate()

  3. Phase de démontage – période de démontage du composant
    componentWillUnmount( )
    Il s'agit de la fonction du cycle de vie des composants à ce stade. Il existait auparavant deux fonctions de cycle de vie appelées getDefaultProps et getInitialState.
    Mais leur fonctionnalité est désormais remplacée par le constructeur.

Scénarios d'utilisation du cycle de vie des composants

  1. constructeur
    Une méthode d'utilisation courante est l'initialisation de l'état

    constructor(props){
        super(props);
        this.state = {
            value:&#39;&#39;
        }}
    Copier après la connexion
    Copier après la connexion
  2. componentWillMount
    Effectuez quelques opérations d'initialisation. Ou effectuez un chargement de données.
    <code> <br/>componentWillMount(){ <br/> this.fetchData(); <br/>} <br/>componentWillMount(){

    this.fetchData();
  3. }

  4. componentWillMount(){    this.fetchData();
    }
    Copier après la connexion
    Copier après la connexion
    componentDidMount
  5. Un scénario courant est la demande de données

  6. render(){    return (
            <p>123</p>
        )
    }
    Copier après la connexion
    Copier après la connexion
    render
  7. Une fonction qui doit être incluse dans un composant React, renvoyant l'élément dom dans la syntaxe jsx


  8. componentWillReceiveProps
  9. Lorsque les accessoires sont passés, certains traitements peuvent être effectués avant le rendu. SetState ne sera pas déclenché deux fois.
  10. Il n'y a qu'un seul paramètre. Représente l'objet props




    shouldComponentUpdate

    Il y a deux paramètres, représentant les accessoires et l'état
  11. Doit renvoyer un vrai ou un faux. Sinon, une erreur de syntaxe sera signalée.
  12. Très utile lors de l'optimisation des performances


  13. componentDidUpdate
  14. Le composant est chargé et certaines opérations sont effectuées



    <br/>componentWillUnMount(){ <br/> clearInterval(this.timer); <br/>} <br/>componentWillUnmount

    Le scénario le plus courant consiste à effacer les setInterval et setTimeout attachés au composant.
  15. </ol>componentWillUnMount(){ <h2> clearInterval(this.timer); </h2>} <div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">常见的使用场景是,根据传递不同的props,渲染不同的界面数据。 项目比较复杂的情况下,一个页面的值发生变化,就要导致另一个页面的值发生改变,这样需要通过props的方式来告知对方,你的值发生改变。让另外一个组件更新dom。需要使用这个周期函数进行监听接受到的props,从而根据这个props进行相应的数据处理。</pre><div class="contentsignin">Copier après la connexion</div></div><div class="contentsignin">Copier après la connexion</div></div>

    这个函数的返回值是一个布尔值。返回一个true。
    返回一个false的情况下,它的的状态不会进行更新。
    Copier après la connexion
    Copier après la connexion

    analyse decomponentWillReceiveProps

    immutable.js
    Copier après la connexion
    Copier après la connexion

    shouldComponentUpdate analyse

    Partie optimisation des performances



    Partie demande de données

    ajax

    En réaction, vous pouvez utiliser l'objet XMLHttpRequest traditionnel pour effectuer des demandes de données.
    var xhr = new XMLHttpRequest();

    xhr.open(type, url, true

    xhr.onReadyStateChange = ()=>{

    if (xhr.readyState == 4 && xhr.status == 200) {

    succès(xhr.responseText);
    }

    }
    const Promise = require(`../vendor/bluebird/bluebird.js`);let get = (url,data) => {    return new Promise((resolve, reject) => {        if(res){
                resolve(res);
            }else if(err){
                reject(err);
            }
        })}
    Copier après la connexion
    Copier après la connexion

    promise

    promise est la méthode de requête de données proposée par es6. Actuellement, de nombreux navigateurs ne l'ont pas encore implémenté. Mais il existe des polyfills pour les promesses, comme blueBird.js

    L'utilisation de base est : Promise object
     fetch("http://homework.shsoapp.com:80/ttzyservice/task/getTaskSubjectList",{        method: &#39;POST&#39;,        headers: {            &#39;Content-Type&#39;: &#39;application/x-www-form-urlencoded&#39;
            },        mode: &#39;cors&#39;,        body: "page=1&rows=10"
        }).then(res =>{        console.log(res);        return res.json()
        }).then(res => {        console.log(res);
        })
    Copier après la connexion
    Copier après la connexion

    fetch

    L'utilisation de base de fetch :
    import { BrowserRouter as Router, Link, Route,Switch} from &#39;react-router-dom&#39;;
    export default class Main extends Component{
        render(){        return(
                <Router>
                    <p>
                        <Switch>
                            <Route path=&#39;/&#39; component={page1}>
                            <Route path=&#39;/home&#39; component={page2}>
                            <Route path=&#39;/age&#39; component={page3}>
                        </Switch>
                    </p>
                </Router>
            )
        }
    }
    Copier après la connexion
    Copier après la connexion

    routage réactif

    Utilisation de base
    const ADD_TASK = "ADD_TASK";const ADD_CONTENT = "ADD_CONTENT";
    
    export function addtask(task){
        return {
            type: ADD_TASK,
            task
        }
    }
    export function addContent(content){
        return {
            type: ADD_CONTENT,
            content
        }
    }
    Copier après la connexion
    Copier après la connexion

    Redux simple et pratique
    import { addtask,addContent } from &#39;actions&#39;;export function(state = &#39;&#39;,action){
        switch (action.type){        case ADD_TASK:            return action.task;            break;        case ADD_CONTENT:            return action.content;            break;        default:            return state;
        }
    }
    Copier après la connexion
    Copier après la connexion

    actions

    对react项目开发,我大概对它的知识点进行了分类,主要由以下几个部分组成。
    Copier après la connexion
    Copier après la connexion

    réducteurs

    import React,{ Component } from &#39;react&#39;;import { render } from &#39;react-dom&#39;;import Main from &#39;./components/Main&#39;;
    
    render(<Main />,document.getElementById(&#39;app&#39;));
    Copier après la connexion
    Copier après la connexion

    Méthode d'écriture de base
    import React,{ Component } from &#39;react&#39;;
    
    export default class Main extends Component{
        render(){        return (
                <p>
                    组件
                </p>
            )
        }
    }
    Copier après la connexion

    Méthode d'écriture de la page d'entrée

    Méthode d'écriture des composants
    父组件传给子组件靠props
    Copier après la connexion
    Copier après la connexion
    import React,{ Component } from &#39;react&#39;;
    import { render } from &#39;react-dom&#39;;class Main extends Component{
        render(){        return (
                <p>
                    <Child  title="我是父组件"/>
                </p>
            )
        }
    }class Child extends Component{
        render(){        return(
                <h2>{this.props.title}</h2>
            )
        }
    }
    render(<Main />,document.getElementById(&#39;app&#39;));
    Copier après la connexion
    Copier après la connexion

    Valeur de passage des composants

    子组件传给父组件靠事件
    子组件传递给父组件的过程描述,父组件传递给子组件一个函数,子组件执行这个函数,然后把子组件自己的值可以通过穿参的方式传递进去。然后父组件接受到这个值,进行相应的操作。
    Copier après la connexion
    Copier après la connexion
    Le composant parent est transmis au composant enfant
    import React,{ Component } from &#39;react&#39;;
    import { render } from &#39;react-dom&#39;;class Main extends Component{
        constructor(props){        super(props);        this.state = {
                value:&#39;init value&#39;
            }
        }
        render(){        return (
                <p>
                    <p>{this.state.value}</p>
                    <Child  onClick={(value)=>{this.setState({value:value})}}/>
                </p>
            )
        }
    }class Child extends Component{
        render(){        return(
                <button onClick={()=>this.props.onClick("子组件的值")}>点击传值</button>
            )
        }
    }
    render(<Main />,document.getElementById(&#39;app&#39;));
    Copier après la connexion
    Copier après la connexion

    webpack的配置一般分为这么几个部分,entry、output、plugin、devServer、module等。
    
    entry告诉webpack入口在哪。
    output告诉webpack将来把文件打包到哪。
    plugin代表一些其他的操作,如打开浏览器、文件压缩等处理。
    devServer代表开发的时候启动一个本地服务器
    module代表各种loader用来解析你的代码。
    Copier après la connexion
    Copier après la connexion
    Le composant enfant est transmis au composant parent

    var webpack = require(&#39;webpack&#39;);module.exports = {    entry:"./src/index.js",    output:{        path:&#39;public&#39;,        filename:&#39;bundle.js&#39;
        },    devServer:{        historyApiFallback:true,        hot:true,        inline:true
        },    plugins:[        new webpack.DefinePlugin({            &#39;process.env.NODE.ENV&#39;: "development"
            }),        new webpack.HotModuleReplacementPlugin(),        new OpenBrowserPlugin({            url: &#39;http://localhost:8080&#39;
            })
        ],    module:{        loaders:[{            test:/\.js[x]?$/,            exclude:/node_modules/,            loader:&#39;babel-loader&#39;,            query:{                presets:[&#39;es2015&#39;,&#39;react&#39;,&#39;stage-1&#39;]
                }
            },{            test:/\.css$/,            loaders:[&#39;style&#39;,css]
            },{            test:/\.(png|jpg)$/,            loader:"url-loader"
            }]
        }
    }
    Copier après la connexion
    Copier après la connexion

    webpack

    Un fichier de configuration webpack normal est le suivant :

    partie es6

    <🎜>Dans React, vous devez généralement connaître une certaine syntaxe es6 Pour réagir, quelques méthodes d'utilisation et d'écriture de base. de es6 sont répertoriés ici. <🎜><🎜>importer et exporter<🎜><🎜>l'importation introduit quelque chose<🎜>
    import webpack from &#39;webpack&#39;;import React from &#39;react&#39;;import { Component } from &#39;react&#39;;
    Copier après la connexion
    Copier après la connexion

    其中使用“{}”引入的变量是那个文件中必须存在的变量名相同的变量。
    不使用“{}”引入的变量是那个文件中export default默认抛出的变量,其中变量名可以不一样。

    export抛出一个东西。

    function a(){    console.log(1);
    }let b = 1;export a;export b;export default a;
    Copier après la connexion
    Copier après la connexion

    其中export可以抛出多个,多次使用。
    export default只能使用一个,表示默认抛出。

    class和extends

    class的本质是一个申明类的关键字。它存在的意义和var、let、const、function等都是一样的。
    使用方式:

    class Main{}
    Copier après la connexion
    Copier après la connexion

    extends代表继承,使用方式:

    class Main extends Component{}
    Copier après la connexion
    Copier après la connexion

    constructor代表构造函数,super是从父类继承属性和方法。

    class Main extends Component{
        constructor(props){        super(props)
        }
    }
    Copier après la connexion
    Copier après la connexion

    生命周期函数

    基本生命周期函数

    分三个状态

    • Mounting

    • Updating

    • Unmounting


    1. Mounting阶段–一般在这个阶段生命周期函数只会执行一次
      constructor()
      componentWillMount()
      componentDidMount()
      render()

    2. Updating阶段–会执行多次
      componentWillReceiveProps()
      shouldComponentUpdate()
      render()
      componentDidUpdate()

    3. Unmountint阶段–组件卸载期
      componentWillUnmount()
      这就是现阶段的组件生命周期函数。之前还有两个生命周期函数叫 getDefaultProps 以及 getInitialState。
      但是它们的功能现在被constructor代替。

    组件的生命周期使用场景

    1. constructor
      常见的一个使用方式就是state的初始化

      constructor(props){
          super(props);
          this.state = {
              value:&#39;&#39;
          }}
      Copier après la connexion
      Copier après la connexion
    2. componentWillMount
      进行一些初始化的操作。或者进行一些数据加载。
      <br/>componentWillMount(){ <br/> this.fetchData(); <br/>} <br/>

    3. componentDidMount
      常见场景就是数据请求

      componentWillMount(){    this.fetchData();
      }
      Copier après la connexion
      Copier après la connexion
    4. render
      一个react组件中必须包含的函数,返回jsx语法的dom元素

      render(){    return (
              <p>123</p>
          )
      }
      Copier après la connexion
      Copier après la connexion
    5. componentWillReceiveProps
      在props传递的时候,可以在render之前进行一些处理。不会触发二次setState。
      只有一个参数。代表的是props对象

    6. shouldComponentUpdate
      有两个参数,分别代表props和state
      必须返回一个true或者false。否则会语法报错。
      在进行一些性能优化的时候非常有用

    7. componentDidUpdate
      组件加载完毕,进行某些操作

    8. componentWillUnmount
      最常见的场景,对组件附加的setInterval、setTimeout进行清除。
      <br/>componentWillUnMount(){ <br/> clearInterval(this.timer); <br/>} <br/>

    componentWillReceiveProps解析

    常见的使用场景是,根据传递不同的props,渲染不同的界面数据。
    项目比较复杂的情况下,一个页面的值发生变化,就要导致另一个页面的值发生改变,这样需要通过props的方式来告知对方,你的值发生改变。让另外一个组件更新dom。需要使用这个周期函数进行监听接受到的props,从而根据这个props进行相应的数据处理。
    Copier après la connexion
    Copier après la connexion

    shouldComponentUpdate解析

    这个函数的返回值是一个布尔值。返回一个true。
    返回一个false的情况下,它的的状态不会进行更新。
    Copier après la connexion
    Copier après la connexion

    性能优化部分

    immutable.js
    Copier après la connexion
    Copier après la connexion

    数据请求部分

    ajax

    在react中,可以使用传统的XMLHttpRequest对象进行数据请求。
    var xhr = new XMLHttpRequest();
    xhr.open(type, url, true);
    xhr.onReadyStateChange = ()=>{
    if (xhr.readyState == 4 && xhr.status == 200) {
    sucess(xhr.responseText);
    }
    }

    promise

    promise是es6提出的数据请求方式。目前很多浏览器还没有实现。但是有promise的polyfill,如blueBird.js
    基本的使用方式是:Promise对象

    const Promise = require(`../vendor/bluebird/bluebird.js`);let get = (url,data) => {    return new Promise((resolve, reject) => {        if(res){
                resolve(res);
            }else if(err){
                reject(err);
            }
        })}
    Copier après la connexion
    Copier après la connexion

    fetch

    fetch的基本使用方式:

     fetch("http://homework.shsoapp.com:80/ttzyservice/task/getTaskSubjectList",{        method: &#39;POST&#39;,        headers: {            &#39;Content-Type&#39;: &#39;application/x-www-form-urlencoded&#39;
            },        mode: &#39;cors&#39;,        body: "page=1&rows=10"
        }).then(res =>{        console.log(res);        return res.json()
        }).then(res => {        console.log(res);
        })
    Copier après la connexion
    Copier après la connexion

    react 路由

    基本使用

    import { BrowserRouter as Router, Link, Route,Switch} from &#39;react-router-dom&#39;;
    export default class Main extends Component{
        render(){        return(
                <Router>
                    <p>
                        <Switch>
                            <Route path=&#39;/&#39; component={page1}>
                            <Route path=&#39;/home&#39; component={page2}>
                            <Route path=&#39;/age&#39; component={page3}>
                        </Switch>
                    </p>
                </Router>
            )
        }
    }
    Copier après la connexion
    Copier après la connexion

    redux的简单实用

    actions

    const ADD_TASK = "ADD_TASK";const ADD_CONTENT = "ADD_CONTENT";
    
    export function addtask(task){
        return {
            type: ADD_TASK,
            task
        }
    }
    export function addContent(content){
        return {
            type: ADD_CONTENT,
            content
        }
    }
    Copier après la connexion
    Copier après la connexion

    reducers

    import { addtask,addContent } from &#39;actions&#39;;export function(state = &#39;&#39;,action){
        switch (action.type){        case ADD_TASK:            return action.task;            break;        case ADD_CONTENT:            return action.content;            break;        default:            return state;
        }
    }
    Copier après la connexion
    Copier après la connexion

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal