IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> [React-通信方式] -> 正文阅读

[JavaScript知识库][React-通信方式]

React-通信方式

写在前面:此笔记跟随尚硅谷课程学习所写

前端请求数据的方式

  • React本身只关注于界面, 并不包含发送ajax请求的代码

  • 前端应用需要通过ajax请求与后台进行交互(json数据)

  • react应用中需要集成第三方ajax库(或自己封装)

常用的ajax库

  • jQuery: 比较重, 如果需要另外引入不建议使用
  • axios: 轻量级, 建议使用
    axios 是基于promise 的网络请求库,可以用在浏览器端和node服务端,在服务端它使用原生 node.js http 模块, 而在客户端 (浏览端) 则使用 XMLHttpRequests。

axios

主要特性

 - 从浏览器创建 XMLHttpRequests对象
 - 从 node.js 创建 http 请求
 - 支持 Promise API 
 - 拦截请求和响应 
 - 转换请求和响应数据 
 - 取消请求
 - 自动转换JSON数据
 - 客户端支持防御XSRF

安装与导入

npm install axios
import axios from 'axios'

使用方式

客户端 axios使用 get请求

1. 带参数方式1 
  axios.get('/user/1234/jack')
     .then(res=>{
			   console.log(res.data)
	 }).catch(err=>{
			   console.log(err)
	 })
   或者
      axios.get('/user/1234/jack').then(
		response=>{
					console.log(response.data)
		},
		error=>{
					console.log(error.message)
		})

2. 带参数方式2 
   axios.get('/user',{
	    params: {
			   id:12334,
			   name:'jack'
			   }
	 }).then(res=>{
			   console.log(res.data)
	 }).catch(err=>{
			   console.log(err)
	 })
 3. 带参数方式3
   axios({
		   method:'GET',
		   url:'/user'params:{
		       id:12334,
			   name:'jack'
		   }
           responseType: 'stream' //表示服务器响应的数据类型
	  }).then(res=>{
			   console.log(res.data)
	  }).catch(err=>{
			   console.log(err)
	  })
4. 多个请求并发的时候
   function reqSend1(){
     axios.get('/user/1234')
   }
   function reqSend2(){
     axios.get('/users/asd')
   }
   Promise.all([reqSend1(),reqSend2()])
   .then(results=>{
       console.log(results)
   })

axios使用 post请求

1.post 请求方式1 
  axios.post('/user',{
     firstName:'jack',
     lastName:'dkj'
     }).then(res=>{
			   console.log(res.data)
	 }).catch(err=>{
			   console.log(err.message)
	 })
2. post请求方式2
  axios({
     method:'post',
     url:'/user/12hdu',
     data:{
       username:'qxf',
       password:'cbdcdhhufv'
     }
   }).then(res=>{
			   console.log(res.data)
	 }).catch(err=>{
			   console.log(err.message)
    })

案列分析:
现在有一个需求,一个输入框一个按钮,在按钮输入内容后点击搜索,发起请求
以gitHub 的用户搜索为例
地址为:https://api.github.com/search/users?q=&{输入框的内容}
在这里插入图片描述
点击搜索后获取请求的数据
在这里插入图片描述
实现如下:

import React, { Component } from 'react'
import { Button} from 'antd'
import axios from 'axios'

export default class Search extends Component {
 handleSearch=()=>{
   //获取用户的输入
   const {value} = this.keyWordElement
   //发送axios请求

axios.get(`https://api.github.com/search/users?q=${value}`).then(
  response=>{
    console.log(response.data)
  },
  error=>{
      console.log(error.response)
  }
)

 }
  render() {
    return (
      <div>
        <input ref={c=>this.keyWordElement=c} type="text" placeholder="输入关键词点击搜索" style={{width:'300px'}}/> &nbsp; &nbsp;
        <Button onClick={this.handleSearch}>搜索</Button>
      </div>
    )
  }
}

消息订阅-发布机制

举个列子:
订阅报纸:
1.交钱,说好地址,订阅哪一种报纸
2.邮递员送报纸
订阅消息:
1.消息名
2.发布消息
综上所述 ,组件之间的通信就是要先订阅消息,才能发布消息

1.工具库: PubSubJS
2.下载: npm install pubsub-js --save
3.使用: 
	1)import PubSub from 'pubsub-js' //引入
	2)PubSub.subscribe('delete', function(data){ }); //订阅 第一个参数是消息名
	3)PubSub.publish('delete', data) //发布消息 第一个参数是消息名 第二个是传递的数据

举例:
现在有一个需求
有一个 Search  组件 包含输入框 和按钮 点击搜索按钮 输入内容点击搜索 向gitHub 发送请求 获取数据传递给 List 组件展示
有一个 List 组件 将 向gitHub 发送请求 获取的数据展示出来

以前的方法思想 子组件---->父组件—>子组件

1. app.jsx 定义初始状态  向Search组件传递 一个函数 updateAppState()
2. Search组件发送请求获取数据  通过this.props.updateAppState("请求的数据")  将数据传递给app.jsx
3.Search()函数 改变后的状态值 传递给List组件  展示信息

现在可以通过发布-订阅模式 不通过父组件的方式 直接实现子组件之间的信息传递。
那么现在方法是:

1. Search 组件发送请求获取数据  发布消息传递数据
2. List 组件 定义初始数据状态 ,订阅消息接收数据,更新数据状态,展示消息

App.jsx

import React,{Component} from 'react'
import Search from './component/Search'
import List from './component/List'
export default class App extends Component{
 render(){
 return(
   <div>
	   <Search/>
	    <List/>
   </div>
 )
}
}

Search/index.jsx 发布消息

import React, { Component } from 'react'
import { Button} from 'antd'
import PubSub from 'pubsub-js' // 引入
import axios from 'axios'

export default class Search extends Component {
 handleSearch=()=>{
   //获取用户的输入
   const {value} = this.keyWordElement
   console.log(value)

   // 还未接收到数据之前 展示 加载中....  信息
    PubSub.publish('atguigu',{isFirst:false,isLoading:true})
   //发送axios请求
    axios.get(`https://api.github.com/search/users?q=${value}`).then(
      response=>{
        // 发布消息  第一个参数是消息名,第二个参数是数据信息
        console.log(response.data)
        PubSub.publish('atguigu',{isLoading:false,users:response.data.items})
      },
      error=>{
           // 发布消息  第一个参数是消息名,第二个参数是数据信息
           PubSub.publish('atguigu',{isLoading:false,err:error.message})
      }
    )

 }
  render() {
    return (
      <div>
        <input ref={c=>this.keyWordElement=c} type="text" placeholder="输入关键词点击搜索" style={{width:'300px'}}/> &nbsp; &nbsp;
        <Button onClick={this.handleSearch}>搜索</Button>
      </div>
    )
  }
}

List/index.jsx 订阅消息

import React,{Component} from 'react'
import PubSub from 'pubsub-js' // 引入

export default class List extends Component{
 state={
   isFirst:true,// 是否第一次打开页面   第一次打开页面 还没有发送请求 提示用户
   isLoading :false,// 标识是否加载中  发送请求 之后还未接收到数据时 展示加载中...
   users:[],//接收的数据信息
   err:''// 如果请求错误展示的信息
  }
  // 打开页面初始化时 要将数据挂载到页面上
  componentDidMount(){
   // 如果发布组件了  现在就接收消息 第一个参数是消息名 第二个参数函数
   // 函数接收两个参数  一个是消息名  一个是数据信息
  this.toaken =  PubSub.subscribe('atguigu',(_,stateObj)=>{
	this.setState(stateObj)
  })
  }
 componentWillUnmount(){
		PubSub.unsubscribe(this.token)
	}
  render() {
	const {users,isFirst,isLoading,err} = this.state
	return (
		<div >
			{
			isFirst ? <h2>欢迎使用,输入关键字,随后点击搜索</h2> :
			isLoading ? <h2>Loading......</h2> :
			err ? <h2 style={{color:'red'}}>{err}</h2> :
			users.map((userObj)=>{
				return (
					<div key={userObj.id} className="card">
						<a rel="noreferrer" href={userObj.html_url} target="_blank">
						<img alt="head_portrait" src={userObj.avatar_url} style={{width:'100px'}}/></a>
						<p className="card-text">{userObj.login}</p>
					</div>
				)
		  })
	    }
     </div>
  )
}
}

fetch发送请求

发送请求的几种方式:

  1. xhr --------------XMLHttpRequest
1)首次创建对象  
   const xhr = new XMLHttpRequest()
 (2)打开请求
   xhr.open('GET','/user/1234',true)
   (3)回调函数
    xhr.onload = function() {//成功
       console.log(xhr.response);
	};
	xhr.onerror = function() {// 失败
	  console.log("Oops, error");
	};
 (4) 发送请求
   xhr.send()
  1. JQuery ------ajax发送请求
$.get(url, data, func, dataType);
1)url:链接地址,字符串表示
2)data:需要发送到服务器的数据,格式为{A: '...', B: '...'}
3)func:请求成功后,服务器回调的函数;function(data, status, xhr),其中data为服务器回传的数据,status为响应状态,xhr为XMLHttpRequest对象,个人感觉关注data参数即可
4)dataType:服务器返回数据的格式
&.get('/user/1234',
	  {id:id,name:name},
	  function(data){
	  // 函数体
	        },
	   'json'
	 		)
  1. axios 发送请求
axios.get(`https://api.github.com/search/users?q=${value}`).then(
      response=>{
        console.log(response.data)
      },
      error=>{
          console.log(error.response)
      }
    )

JQuery 和axios都是对XMLHttpRequest 对象的封装 使用这两种方法发送请求都需要下载在引入。 现在有另一种方法 ,不需要下载引用,是Window内置方法就有的,也可以发送请求,和XHR地位并列,是不用XHR就可以发送请求的方法。

fetch发送请求

关注分离的设计思想
简单来说就是将一件复杂的事情拆分成多个简单的步骤,进行解决
特点

  1. fetch: 原生函数,不再使用XmlHttpRequest对象提交ajax请求
  2. 老版本浏览器可能不支持(所以用的较少)

案列:还是上面的列子 现在换一种fetch 方法请求数据获取信息

Search/index.jsx 发布消息--------fetch 请求----未优化版本

import React, { Component } from 'react'
import { Button} from 'antd'
import PubSub from 'pubsub-js' // 引入
import axios from 'axios'

export default class Search extends Component {
 handleSearch=()=>{
   //获取用户的输入
   const {value} = this.keyWordElement
   console.log(value)
   // fetch请求获取数据
   fectch('`https://api.github.com/search/users?q=${value}`)
   .then(
		   response=>{
		   // 这一步只是简单测试 连接有没有成功 但是没有返回数据
		   // 而且不管地址有没有正确 都会走这一步 就是也是联系服务器成功但是返回404
		        console.log('联系服务器成功了',response)
		       // 如果联系服务器成功 response.json()方法会返回一个promise 对象,这个对象里包含了请求的数据信息
		       return response.json()
		     },
		    error>{
		    // 当处于离线状态再去获取请求就会 显示联系服务器失败
		        console.log('联系服务器失败了',error)
		       //  如果联系服务器都失败了 就不在二次调用.then() 中断
		       return new Promise(()=>{})
		     }
   ).then(
   //之所以可以第二次调用 then(),是因为第一个.then()方法的返回值仍然是一个promise对象
    // 如果.then() 所指定的成功的回调或者失败的回调的返回值是一个非promise值,那么promise 的值的实例是成功的,值就是这个 非promise的值
   //如果.then() 所指定的成功的回调或者失败的回调的返回值是一个promise值,那么promise 的值的实例是成功的,值就是这个promise的值
   response=>{
        console.log('获取数据成功',response)
    },
    error=>{
         console.log('获取数据失败',error)
    }
   )

 }
  render() {
    return (
      <div>
        <input ref={c=>this.keyWordElement=c} type="text" placeholder="输入关键词点击搜索" style={{width:'300px'}}/> &nbsp; &nbsp;
        <Button onClick={this.handleSearch}>搜索</Button>
      </div>
    )
  }
}

Search/index.jsx 发布消息--------fetch 请求----优化版本

import React, { Component } from 'react'
import { Button} from 'antd'
import PubSub from 'pubsub-js' // 引入
import axios from 'axios'

export default class Search extends Component {
 handleSearch=()=>{
   //获取用户的输入
   const {value} = this.keyWordElement
   console.log(value)
   // fetch请求获取数据
   try{
    const  response = await  fectch('`https://api.github.com/search/users?q=${value}`)
    const data = await response.json()
    console.log('data')
    PubSub.publish('atguigu',{isLoading:false,users:data.items})
   }.catch(error){
     console.log('请求出错',error);
	PubSub.publish('atguigu',{isLoading:false,err:error.message})
   }  	
 }
  render() {
    return (
      <div>
        <input ref={c=>this.keyWordElement=c} type="text" placeholder="输入关键词点击搜索" style={{width:'300px'}}/> &nbsp; &nbsp;
        <Button onClick={this.handleSearch}>搜索</Button>
      </div>
    )
  }
}


参考:
1.尚硅谷视频
2.https://axios-http.com/zh/docs/intro

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-30 00:43:36  更:2022-09-30 00:44:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 15:54:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码