react github搜索案例 知识点总结

最终效果

在这里插入图片描述

1.ES6知识点:解构赋值+重命名

let obj ={a,{b:2}}
const {a} = obj					// 传统解构赋值
const {a:{b}} = obj				// 连续解构赋值
const {a:{b:value}} = obj		// 连续解构赋值+重命名

2.消息订阅与发布机制

  1. 先订阅,再发布
  2. 适用于任何组件内的通信
  3. 在 componentWillUnmount() 中取消订阅
// 订阅
this.token = Pubsub.subscribe('updateListState', (_, data) => {
      this.setState(data)
    })
// 更新信息
 Pubsub.publish('updateListState', { isLoading: false, users: data.items })
 // 取消订阅
 Pubsub.unsubscribe(this.token)

3.fetch发送请求(关注分离设计思想)

要处理请求失败的情况

try {
      const reponse = await fetch(`/api1/search/users2?q=${keyword}`)
      const data = await reponse.json()
      Pubsub.publish('updateListState', { isLoading: false, users: data.items })
    } catch (error) {
      console.log('请求出错', error)
      Pubsub.publish('updateListState', { isLoading: false, err: '请求出错:' + error.message })
    }

github链接

github搜索案例

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值