Table des matières
Méthode 2 : Créez le fichier setupProxy.js dans le répertoire src" >Méthode 2 : Créez le fichier setupProxy.js dans le répertoire src
Étape 1 : Webpack est configuré Appelez la fonction configurée dans setupProxy.js" >Étape 1 : Webpack est configuré Appelez la fonction configurée dans setupProxy.js
Mécanisme d'abonnement et de publication des messages " >Mécanisme d'abonnement et de publication des messages
Avantages " > Avantages
Maison interface Web Questions et réponses frontales Comment implémenter les données de requête backend de réaction

Comment implémenter les données de requête backend de réaction

Dec 29, 2022 pm 01:48 PM
react

Comment implémenter les données de requête backend de réaction : 1. Configurez ""proxy": "http://localhost:5000"" dans package.json ; 2. Créez le fichier "setupProxy.js" dans le répertoire src ; . , appelez la fonction configurée dans "setupProxy.js", le code est tel que "createProxyMiddleware('/api2',{target:...}".

Comment implémenter les données de requête backend de réaction

L'environnement d'exploitation de ce tutoriel : système Windows10. , version React18.0.0, ordinateur Dell G3

Comment demander des données au back-end React ? nous voulons proxy vers

 "proxy":"http://localhost:5000"
Copier après la connexion

Obtenez les données de /students dans localhost:5000

**Avantages : **Configuration simple, la demande de ressources frontale ne nécessite aucun préfixe**Inconvénients : **Impossible de configurer plusieurs serveurs proxy

Méthode 2 : Créez le fichier setupProxy.js dans le répertoire src

Étape 1 : Webpack est configuré Appelez la fonction configurée dans setupProxy.js

  • Étape 2 : Configurer
  •   getStudentData = () => {
        axios.get('/students').then(
          (result) => { console.log(result.data); },
          (reason) => { console.log(reason); })
      }
    Copier après la connexion
  • Lien pour résoudre le problème : https://www.csdn.net/tags/OtTaIg0sNzE3OC1ibG9n.html

Demande inter-domaine, cas d'interface réel

    App.jsx
  • //const proxy=require("http-proxy-middleware")   :视频中请求的包,引用它出现了无法访问的问题//应该使用以下写法*******const { createProxyMiddleware } = require("http-proxy-middleware");module.exports=function(app){
        app.use(
            createProxyMiddleware('/api1',{//遇见/api1前缀的请求,就会触发该代理配置
                target:"http://localhost:5000",//请求转发给谁
                changeOrigin:true,//控制服务器收到的请求头中Host字段的值:host就是主机名+端口号
                	//true:后端接收到的host:localhost:5000
                	//false:后端接收到的host:localhost:3000
                	//系统默认为false,一般会设为true
                pathRewrite:{"^/api1":""}//重写请求路径(必须要写)
                //不写:后台接收到的请求路径:/api1/student
                //写了:后台请求的路径:/student
            }),
            createProxyMiddleware('/api2',{
                target:"http://localhost:5001",
                changeOrigin:true,
                pathRewrite:{"^/api2":""}
            }),
        )}
    Copier après la connexion
  • Search.jsxsetupProxy.js

import React, { Component } from 'react'
import Search from './components/Search'
import List from './components/List'
import './App.css'

export default class App extends Component {
state={users:[]}
getSearchResult=(result)=>{
  this.setState({users:result})
}

  render() {
    return (
      <div className="container">
        <Search getSearchResult={this.getSearchResult}/>
        <List users={this.state.users}/>
      </div>
    )
  }
}
Copier après la connexion
  • List.jsx
  • import React, { Component } from 'react'
    import axios from 'axios'
    import './index.css'
    
    export default class Search extends Component {
    
      search = () => {
        //获取输入框中的值
        const { value } = this.keyWordElement;
        //发送请求
        axios.get(`/api1/search/users?q=${value}`).then(
          result => {
            this.props.getSearchResult(result.data.items)
          },
          reason => {
            console.log(reason);
          })
      }
    
    
    
      render() {
        return (
          <section className="jumbotron">
            <h3 className="jumbotron-heading">搜索github用户</h3>
            <div>
              <input ref={c => this.keyWordElement = c} type="text" placeholder="enter the name you search" /> <button onClick={this.search}>搜索</button>
            </div>
          </section>
        )
      }
    }
    Copier après la connexion
  • react-any composant Communication
  • Mécanisme d'abonnement et de publication des messages

      PubSubJs :
    • pub : (publier) publier
    • sub : (s'abonner) s'abonner
    • pubsub-js
    •  : est utilisé pour implémenter la publication et l'abonnement. Vous pouvez considérer eventBus dans vue comme un support de fonctions
    • .

      Abonné : créez une fonction et transmettez cette fonction à pubsub pour l'hébergement

    import React, { Component } from 'react'
    
    import './index.css'
    export default class List extends Component {
      render() {
        return (
          <div className="row">
            {this.props.users.map(item=>{
                return    <div key={item.id} className="card">
                    <a href={item.html_url} target="_blank">
                      <img src={item.avatar_url} style={{ width: "100px" }} />
                    </a>
                    <p className="card-text">{item.login}</p>
                  </div>
            })}
      
           
          </div>  
        )
      }
    }
    Copier après la connexion

    Éditeur : publié Cela signifie qu'en appelant la fonction spécifiée par l'abonné, la fonction de transmission de paramètres ou d'exécution d'opérations est réalisée

    var token=PubSub.subscribe("myTopic",myFunction[托管的函数])//token,是当前订阅函数的唯一id,可以用来取消订阅
    Copier après la connexion
    • Étape 1
    •  : Ajouter pubsub-js

    PubSub.publish('myTopic','需要发送给订阅者的内容')
    Copier après la connexion
    **Étape 2 :* *Importer
    • yarn add pubsub-js
      Copier après la connexion
      • ** dans le composant **Étape 3 : * *Appelez la fonction d'abonnement PubSub (généralement souscrite dans la fonction hook du composantDidMount)
    import PubSub from 'pubsub-js'
    Copier après la connexion
    • demo
  • List Quelles sont les manières d'envoyer une requête ajax ?

    xhr:xmlHttpRequest : ajax traditionnel

      jQuery : xhr encapsulé
    • axios : xhr encapsulé

      **fetch(fetch)?* Fenêtre intégrée, pas besoin d'emprunter des bibliothèques tierces, utilisez-la directement
    • Inconvénients : Ce n'est pas très utile pour le moment, il n'y a pas d'intercepteur d'envoi de requête

    xhr

    fetch

    Inconvénients

     : Pas de compatibilité élevée

    Avantages

    : Aucun Utilisez xhr , pas besoin d'installer des bibliothèques tierces, natif

      • récupérez la méthode d'écriture optimale
        componentDidMount(){
          this.token=PubSub.subscribe("changeState",this.changeStateObj)
        }
      Copier après la connexion
      recommande d'apprendre : "
    • tutoriel vidéo React
    • "

    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!

    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

    Outils d'IA chauds

    Undresser.AI Undress

    Undresser.AI Undress

    Application basée sur l'IA pour créer des photos de nu réalistes

    AI Clothes Remover

    AI Clothes Remover

    Outil d'IA en ligne pour supprimer les vêtements des photos.

    Undress AI Tool

    Undress AI Tool

    Images de déshabillage gratuites

    Clothoff.io

    Clothoff.io

    Dissolvant de vêtements AI

    Video Face Swap

    Video Face Swap

    Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

    Outils chauds

    Bloc-notes++7.3.1

    Bloc-notes++7.3.1

    Éditeur de code facile à utiliser et gratuit

    SublimeText3 version chinoise

    SublimeText3 version chinoise

    Version chinoise, très simple à utiliser

    Envoyer Studio 13.0.1

    Envoyer Studio 13.0.1

    Puissant environnement de développement intégré PHP

    Dreamweaver CS6

    Dreamweaver CS6

    Outils de développement Web visuel

    SublimeText3 version Mac

    SublimeText3 version Mac

    Logiciel d'édition de code au niveau de Dieu (SublimeText3)

    Comment créer une application de chat en temps réel avec React et WebSocket Comment créer une application de chat en temps réel avec React et WebSocket Sep 26, 2023 pm 07:46 PM

    Comment créer une application de chat en temps réel à l'aide de React et WebSocket Introduction : Avec le développement rapide d'Internet, la communication en temps réel a attiré de plus en plus d'attention. Les applications de chat en direct font désormais partie intégrante de la vie sociale et professionnelle moderne. Cet article expliquera comment créer une application simple de chat en temps réel à l'aide de React et WebSocket, et fournira des exemples de code spécifiques. 1. Préparation technique Avant de commencer à créer une application de chat en temps réel, nous devons préparer les technologies et outils suivants : React : un pour la construction

    Guide pour la séparation du front-end et du back-end de React : Comment réaliser le découplage et le déploiement indépendant du front-end et du back-end Guide pour la séparation du front-end et du back-end de React : Comment réaliser le découplage et le déploiement indépendant du front-end et du back-end Sep 28, 2023 am 10:48 AM

    Guide de séparation front-end et back-end de React : Comment réaliser un découplage front-end et back-end et un déploiement indépendant, des exemples de code spécifiques sont nécessaires Dans l'environnement de développement Web actuel, la séparation front-end et back-end est devenue une tendance. En séparant le code front-end et back-end, le travail de développement peut être rendu plus flexible, plus efficace et faciliter la collaboration en équipe. Cet article expliquera comment utiliser React pour réaliser une séparation front-end et back-end, atteignant ainsi les objectifs de découplage et de déploiement indépendant. Tout d’abord, nous devons comprendre ce qu’est la séparation front-end et back-end. Dans le modèle de développement Web traditionnel, le front-end et le back-end sont couplés

    Comment créer des applications Web simples et faciles à utiliser avec React et Flask Comment créer des applications Web simples et faciles à utiliser avec React et Flask Sep 27, 2023 am 11:09 AM

    Comment utiliser React et Flask pour créer des applications Web simples et faciles à utiliser Introduction : Avec le développement d'Internet, les besoins des applications Web deviennent de plus en plus diversifiés et complexes. Afin de répondre aux exigences des utilisateurs en matière de facilité d'utilisation et de performances, il devient de plus en plus important d'utiliser des piles technologiques modernes pour créer des applications réseau. React et Flask sont deux frameworks très populaires pour le développement front-end et back-end, et ils fonctionnent bien ensemble pour créer des applications Web simples et faciles à utiliser. Cet article détaillera comment exploiter React et Flask

    Comment créer une application de messagerie fiable avec React et RabbitMQ Comment créer une application de messagerie fiable avec React et RabbitMQ Sep 28, 2023 pm 08:24 PM

    Comment créer une application de messagerie fiable avec React et RabbitMQ Introduction : Les applications modernes doivent prendre en charge une messagerie fiable pour obtenir des fonctionnalités telles que les mises à jour en temps réel et la synchronisation des données. React est une bibliothèque JavaScript populaire pour créer des interfaces utilisateur, tandis que RabbitMQ est un middleware de messagerie fiable. Cet article explique comment combiner React et RabbitMQ pour créer une application de messagerie fiable et fournit des exemples de code spécifiques. Présentation de RabbitMQ :

    Guide de l'utilisateur de React Router : Comment implémenter le contrôle de routage frontal Guide de l'utilisateur de React Router : Comment implémenter le contrôle de routage frontal Sep 29, 2023 pm 05:45 PM

    Guide de l'utilisateur de ReactRouter : Comment implémenter le contrôle du routage frontal Avec la popularité des applications monopage, le routage frontal est devenu un élément important qui ne peut être ignoré. En tant que bibliothèque de routage la plus populaire de l'écosystème React, ReactRouter fournit des fonctions riches et des API faciles à utiliser, rendant la mise en œuvre du routage frontal très simple et flexible. Cet article expliquera comment utiliser ReactRouter et fournira quelques exemples de code spécifiques. Pour installer ReactRouter en premier, nous avons besoin

    Comment créer une application d'analyse de données rapide à l'aide de React et Google BigQuery Comment créer une application d'analyse de données rapide à l'aide de React et Google BigQuery Sep 26, 2023 pm 06:12 PM

    Comment utiliser React et Google BigQuery pour créer des applications d'analyse de données rapides Introduction : À l'ère actuelle d'explosion de l'information, l'analyse des données est devenue un maillon indispensable dans diverses industries. Parmi eux, créer des applications d’analyse de données rapides et efficaces est devenu l’objectif poursuivi par de nombreuses entreprises et particuliers. Cet article explique comment utiliser React et Google BigQuery pour créer une application d'analyse rapide des données et fournit des exemples de code détaillés. 1. Présentation React est un outil pour créer

    Comment créer des applications de traitement de données en temps réel à l'aide de React et Apache Kafka Comment créer des applications de traitement de données en temps réel à l'aide de React et Apache Kafka Sep 27, 2023 pm 02:25 PM

    Comment utiliser React et Apache Kafka pour créer des applications de traitement de données en temps réel Introduction : Avec l'essor du Big Data et du traitement de données en temps réel, la création d'applications de traitement de données en temps réel est devenue la priorité de nombreux développeurs. La combinaison de React, un framework front-end populaire, et d'Apache Kafka, un système de messagerie distribué hautes performances, peut nous aider à créer des applications de traitement de données en temps réel. Cet article expliquera comment utiliser React et Apache Kafka pour créer des applications de traitement de données en temps réel, et

    Comment empaqueter et déployer des applications frontales à l'aide de React et Docker Comment empaqueter et déployer des applications frontales à l'aide de React et Docker Sep 26, 2023 pm 03:14 PM

    Comment utiliser React et Docker pour empaqueter et déployer des applications frontales L'empaquetage et le déploiement d'applications frontales sont une partie très importante du développement de projet. Avec le développement rapide des frameworks front-end modernes, React est devenu le premier choix de nombreux développeurs front-end. En tant que solution de conteneurisation, Docker peut grandement simplifier le processus de déploiement d'applications. Cet article explique comment utiliser React et Docker pour empaqueter et déployer des applications frontales et fournit des exemples de code spécifiques. 1. Préparation Avant de commencer, nous devons installer

    See all articles