日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
React高階用法之RenderProps

 什么是Render Props
“render prop”是指一種在React組件之間使用值為函數(shù)的prop共享代碼的技術(shù)

創(chuàng)新互聯(lián)建站主要業(yè)務(wù)有網(wǎng)站營(yíng)銷策劃、成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、微信公眾號(hào)開(kāi)發(fā)、小程序設(shè)計(jì)、H5響應(yīng)式網(wǎng)站、程序開(kāi)發(fā)等業(yè)務(wù)。一次合作終身朋友,是我們奉行的宗旨;我們不僅僅把客戶當(dāng)客戶,還把客戶視為我們的合作伙伴,在開(kāi)展業(yè)務(wù)的過(guò)程中,公司還積累了豐富的行業(yè)經(jīng)驗(yàn)、營(yíng)銷型網(wǎng)站資源和合作伙伴關(guān)系資源,并逐漸建立起規(guī)范的客戶服務(wù)和保障體系。 

這個(gè)概念聽(tīng)上去有點(diǎn)拗口,我們拆開(kāi)了看它。

首先它本質(zhì)上是一個(gè)prop,是用來(lái)父子組件之間傳遞數(shù)據(jù)用的
其次這個(gè)prop傳遞的值是一個(gè)函數(shù)
最后它取名render props,是因?yàn)樗ǔJ怯脕?lái)render(渲染)某個(gè)元素或組件
比如官網(wǎng)給出的示例:

 
 
  1.  (
  2.   

    Hello {data.target}

  3. )}/>

我們給 這個(gè)子組件傳遞了一個(gè)叫 render 的prop,這個(gè)prop的值是一個(gè)函數(shù),它返回了一個(gè) h1 元素。然后我們可以假裝實(shí)現(xiàn)一下這個(gè) 組件:

 
 
  1. class DataProvider extends React.Component {
  2.     state = {
  3.         data: {
  4.             target: 'World'
  5.         }
  6.     }
  7.     render() {
  8.         return this.props.render(this.state)
  9.     }
  10. }

最終我們的 DataProvider 組件渲染的結(jié)果就是

Hello World

。有同學(xué)可能會(huì)有疑問(wèn),為什么要費(fèi)這么大周折?直接把 h1 元素寫(xiě)在 DataProvider 組件里不也可以嗎?

這里就要講到代碼的可復(fù)用性了,假如下次我們希望 DataProvider 組件渲染的結(jié)果就是 Hello World 呢?難道又去修改 DataProvider 組件嗎?有了render props,我們就可以動(dòng)態(tài)地決定 DataProvider 組件內(nèi)部要渲染的元素,同時(shí)這個(gè)元素還可以使用到 DataProvider 組件內(nèi)部的數(shù)據(jù)。

實(shí)際項(xiàng)目案例
下面講一個(gè)實(shí)際的項(xiàng)目案例,下圖中我們有一個(gè)橫向滾動(dòng)的 ScrollView 組件,這個(gè)組件本身是個(gè)很普通的

元素, 只不過(guò)樣式上加了 overflow-x: scroll 所以可以橫向滾動(dòng)起來(lái)。產(chǎn)品同學(xué)說(shuō)滾動(dòng)區(qū)域的下方要有進(jìn)度點(diǎn)指示,從而告訴用戶總共有幾個(gè)產(chǎn)品,已經(jīng)現(xiàn)在滾到第幾個(gè)產(chǎn)品了。

明確了產(chǎn)品需求以后,我們就開(kāi)始來(lái)實(shí)現(xiàn),首先看下第一版:

 
 
  1. class demo extends Component {
  2.     state = {
  3.       activeIndicator: 0,
  4.       list: []
  5.     }
  6.     
  7.     onScroll = () => {
  8.         const { list } = this.state;
  9.         const container = findDOMNode(this.refs.container);
  10.         ...
  11.         const itemVisibleLengthInContainer = list.map((item, index) => {
  12.           const node = findDOMNode(this.refs[`item-${index}`]);
  13.            ...
  14.         });
  15.         this.setState({
  16.           activeIndicator: active,
  17.         });
  18.     };
  19.     
  20.     render() {
  21.         const { list, activeIndicator } = this.state;
  22.         return (
  23.              
  24.                 ref="container"
  25.                 horizontal={true}
  26.                 onScroll={this.onScroll}
  27.              >
  28.                 {list.map((item,i) => (
  29.                     
  30.                         ref={`item-${i}`}
  31.                         data={item}
  32.                     />
  33.                  ))}
  34.                  
  35.              
  36.              
  37.         )
  38.     }
  39. }

ok,需求我們已經(jīng)實(shí)現(xiàn)了。實(shí)現(xiàn)邏輯就是給 ScrollView 組件添加一個(gè) onScroll 事件,每當(dāng)滾動(dòng)的時(shí)候,會(huì)先計(jì)算 ScrollView 容器的位置信息,和每一個(gè) ProductItem 的位置信息,算出現(xiàn)在哪個(gè) ProductItem 在 ScrollView 容器中所占比例最高,從而得出現(xiàn)在應(yīng)該高亮的 activeIndicator 。

不過(guò)現(xiàn)在有個(gè)問(wèn)題哦,給 ScrollView 組件增加進(jìn)度指示器這個(gè)功能,更像是 ScrollView 組件應(yīng)該支持的一個(gè)功能,而不是直接寫(xiě)在業(yè)務(wù)代碼里。所以我們應(yīng)該提供一個(gè)新組件 ScrollViewWithIndicator ,讓它去處理進(jìn)度指示器的問(wèn)題,從而跟業(yè)務(wù)解耦。

 
 
  1. class ScrollViewWithIndicator extends Component {
  2.     state = {
  3.       activeIndicator: 0,
  4.     }
  5.     
  6.     onScroll = () => {
  7.         const { list } = this.props;
  8.         const container = findDOMNode(this.refs.container);
  9.         ...
  10.         const itemVisibleLengthInContainer = list.map((item, index) => {
  11.           const node = findDOMNode(this.refs[`item-${index}`]);
  12.            ...
  13.         });
  14.         this.setState({
  15.           activeIndicator: active,
  16.         });
  17.     };
  18.     
  19.     render() {
  20.         const [{ list, children, ...restProps } , { activeIndicator }] = [this.props, this.state];
  21.         return (
  22.              
  23.                 ref="container"
  24.                 {...restProps}
  25.                 onScroll={this.onScroll}
  26.              >
  27.                 {list.map((item,i) => (
  28.                        
  29.                         {children(item}
  30.                     
  •                  ))}
  •                  
  •              
  •              
  •         )
  •     }
  • }
  • 然后我們的業(yè)務(wù)代碼就可以簡(jiǎn)化了:

     
     
    1. class demo extends Component {
    2.     state = {
    3.       list: []
    4.     }
    5.     render() {
    6.         const { list } = this.state;
    7.         return (
    8.               
    9.                 horizontal={true}
    10.                 list={list}
    11.              >
    12.               {child => }  //(*)
    13.              
    14.         )
    15.     }

    仔細(xì)看業(yè)務(wù)代碼demo組件,我們一共給ScrollViewWithIndicator組件傳遞了多少個(gè)props?答案是三個(gè)!分別是horizontal, list ,children,大家千萬(wàn)別忘了this.props.children也是一個(gè)props哦

    再仔細(xì)看第(*)這句話,我們給ScrollViewWithIndicator組件傳遞一個(gè)叫children的prop,同時(shí)這個(gè)prop是一個(gè)函數(shù),返回了一個(gè)組件(元素),這就是我們所說(shuō)的render props啊

    為什么list.map這個(gè)數(shù)組的遍歷要寫(xiě)在ScrollViewWithIndicator組件內(nèi)部,而不是業(yè)務(wù)組件demo里呢?因?yàn)槲覀冊(cè)趏nScroll 事件回調(diào)函數(shù)里要計(jì)算每一個(gè)商品item的位置,也就是要拿到商品item的ref屬性,所以把數(shù)組的遍歷寫(xiě)在ScrollViewWithIndicator 組件內(nèi)部方便我們顯性給每一個(gè)商品item聲明ref屬性


    名稱欄目:React高階用法之RenderProps
    本文網(wǎng)址:http://m.5511xx.com/article/djjoede.html