真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

react-refetch怎么用-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)react-refetch怎么用的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

10年積累的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有鐵東免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

使用react-refetch來簡化api獲取數(shù)據(jù)的代碼

const List = ({data: gists}) => {
 return (
  
       {gists.map(gist => (     {gist.description}    ))}   
 ) } const withData = url => Part => {  return class extends Component {   state = {data: []}   componentDidMount() {    fetch(url)     .then(response => response.json ? response.json() : response)     .then(data => this.setState({data}))   }   render() {    return    }  } } const ListWithGists = withData('https://api.github.com/users/gaearon/gists')(List)

上面的代碼,我們將api獲取數(shù)據(jù)的邏輯用高階組件抽離出來,下面我們?cè)儆胷eact-refetch來簡化上面的異步代碼

import { connect as refetchConnect } from 'react-refetch'

const List = ({gists}) => {
 if (gists.pending) {
  return 
loading...
 } else if (gists.rejected) {   return 
{gists.reason}
 } else if (gists.fulfilled) {   return (    gists.fulfilled && 
        {gists.value.map(gist => (      {gist.description}     ))}    
  )  } } const ListWithGists = refetchConnect(() => ({gists: `https://api.github.com/users/gaearon/gists`}))(List)

瞬間清爽多了,順便利用react-refetch提供的屬性,順便把loading邏輯也添加了

分離列表和項(xiàng)目的職責(zé)

很明顯,List組件是一個(gè)渲染列表的組件,他的職責(zé)就是渲染列表,但是我們?cè)谶@里也處理了單個(gè)Item的邏輯,我們可以將其進(jìn)行職責(zé)分離,List只做列表染,而Gist也只渲染自身

const Gist = ({description}) => (
 
  •   {description}  
  • ) const List = ({gists}) => {  if (gists.pending) {   return 
    loading...
     } else if (gists.rejected) {   return 
    {gists.reason}
     } else if (gists.fulfilled) {   return (    gists.fulfilled && 
          {gists.value.map(gist => )}    
      )  } }

    使用react-refetch來給Gist添加功能

    react-refetch的connect方法接收一個(gè)函數(shù)作為參數(shù),這個(gè)函數(shù)返回一個(gè)對(duì)象,如果結(jié)果對(duì)象的值是一個(gè)字符串,那么獲取prop后,會(huì)對(duì)這個(gè)字符串發(fā)起請(qǐng)求,但是如果值是一個(gè)函數(shù),那么不會(huì)立即執(zhí)行,而是會(huì)傳遞給組件,以便后續(xù)使用

    值為字符串

    const connectWithStar = refetchConnect(() => ({gists: `https://api.github.com/users/gaearon/gists`}))

    值為函數(shù)

    const connectWithStar = refetchConnect(({id}) => ({
     star: () => ({
      starResponse: {
       url: `https://api.github.com/gists/${id}/star?${token}`,
       method: 'PUT'
      }
     })
    }))
    
    const Gist = ({description, star}) => (
     
  •   {description}   +1  
  • )

    加工Gist組件,star函數(shù)會(huì)被傳遞給Gist的prop,然后就可以在Gist里面使用了

    connectWithStar(Gist)

    感謝各位的閱讀!關(guān)于“react-refetch怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

    另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。


    網(wǎng)頁題目:react-refetch怎么用-創(chuàng)新互聯(lián)
    標(biāo)題路徑:http://weahome.cn/article/ecpsg.html

    其他資訊

    在線咨詢

    微信咨詢

    電話咨詢

    028-86922220(工作日)

    18980820575(7×24)

    提交需求

    返回頂部