Trabalhando com RxJS e ReactJS

Neste capítulo, veremos como usar RxJs com ReactJS. Não entraremos no processo de instalação do Reactjs aqui, para saber sobre a instalação do ReactJS consulte este link: /reactjs/reactjs_environment_setup.htm

Exemplo

Trabalharemos diretamente em um exemplo abaixo, onde usaremos Ajax do RxJS para carregar dados.

index.js

import React, { Component } from "react";
import ReactDOM from "react-dom";
import { ajax } from 'rxjs/ajax';
import { map } from 'rxjs/operators';
class App extends Component {
   constructor() {
      super();
      this.state = { data: [] };
   }
   componentDidMount() {
      const response = ajax('https://jsonplaceholder.typicode.com/users').pipe(map(e => e.response));
      response.subscribe(res => {
         this.setState({ data: res });
      });
   }
   render() {
      return (
         <div>
            <h3>Using RxJS with ReactJS</h3>
            <ul>
               {this.state.data.map(el => (
                  <li>
                     {el.id}: {el.name}
                  </li>
               ))}
            </ul>
         </div>
      );
   }
}
ReactDOM.render(<App />, document.getElementById("root"));

index.html

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "UTF-8" />
      <title>ReactJS Demo</title>
   <head>
   <body>
      <div id = "root"></div>
   </body>
</html>

Usamos o ajax do RxJS que irá carregar os dados deste Url -https://jsonplaceholder.typicode.com/users.

Quando você compila, a exibição é como mostrado abaixo -