依賴內(nèi)層DOMsize設(shè)定外層DOM的size

遇到的問題

在應(yīng)用scrollPane組件包裹tree組件的時(shí)候,由于flex布局蚪腋,內(nèi)層組件超出部分不會(huì)自動(dòng)超出外層父組件孵淘,這時(shí)候需要手動(dòng)去設(shè)置內(nèi)層組件的size瞧挤。

一開始,想當(dāng)然在tree組件componentDidMount中根據(jù)tree的scrollWidth描焰,scrollHeight來init tree size媳否。然后在在 componentWillReceiveProps中再次獲取 this.refs.tree的scroll size重新設(shè)置tree size【G兀或者在componentDidUpdate中獲取 this.refs.tree的scroll size重新設(shè)置tree size逆日。

bug原因

但是,由于在componentDidMount中init了 tree size萄凤,在componentWillReceiveProps和componentDidUpdate中獲取this.refs.tree 的scroll size還是第一次設(shè)置的大小室抽。這時(shí)候我們就會(huì)獲取不到正確的 scroll size。

解決方法:

在componentWillReceiveProps中取消init的tree size 然后在獲取其size靡努,再根據(jù)獲取的數(shù)據(jù)進(jìn)行后續(xù)操作坪圾。

關(guān)鍵代碼如下:

Class Tree extends React.Component {
  constructor(props) {
    //...code...
    this.state = {
      //...code...
      treeWidth: null
      //...code...
    }
    //...code...
  }

  componentDidMount() {
    //...code...
    this._treeWidth = this.refs.tree.scrollWidth;
    this.setState({
        treeWidth: this._treeWidth
    })
    //...code...
  }

  componentWillReceiveProps() {
    //...code...
    this.setState({
        treeWidth: null
    }, () => {
      if(this.refs.tree.scrollWidth !== this._treeWidth) {
        this._treeWidth = this.refs.tree.scrollWidth;
      }

      this.setState({
        treeWidth: this._treeWidth
      })
    })
    //...code...
  }

  render() {
   //...code...
   return (
      <div ref='tree' style={this.state.treeWidth ? {width: `${this.state.treeWidth}px`}} /*...*/>
         //...
      </div>
   )
  }

  //...code...
}

個(gè)人經(jīng)驗(yàn),歡迎指正惑朦。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末兽泄,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子漾月,更是在濱河造成了極大的恐慌病梢,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,919評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異蜓陌,居然都是意外死亡觅彰,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門钮热,熙熙樓的掌柜王于貴愁眉苦臉地迎上來填抬,“玉大人,你說我怎么就攤上這事隧期§穑” “怎么了?”我有些...
    開封第一講書人閱讀 163,316評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵仆潮,是天一觀的道長(zhǎng)宏蛉。 經(jīng)常有香客問我,道長(zhǎng)性置,這世上最難降的妖魔是什么檐晕? 我笑而不...
    開封第一講書人閱讀 58,294評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮蚌讼,結(jié)果婚禮上辟灰,老公的妹妹穿的比我還像新娘。我一直安慰自己篡石,他們只是感情好芥喇,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評(píng)論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著凰萨,像睡著了一般继控。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上胖眷,一...
    開封第一講書人閱讀 51,245評(píng)論 1 299
  • 那天武通,我揣著相機(jī)與錄音,去河邊找鬼珊搀。 笑死冶忱,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的境析。 我是一名探鬼主播囚枪,決...
    沈念sama閱讀 40,120評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼劳淆!你這毒婦竟也來了链沼?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,964評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤沛鸵,失蹤者是張志新(化名)和其女友劉穎括勺,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,376評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡疾捍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評(píng)論 2 333
  • 正文 我和宋清朗相戀三年奈辰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拾氓。...
    茶點(diǎn)故事閱讀 39,764評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡冯挎,死狀恐怖底哥,靈堂內(nèi)的尸體忽然破棺而出咙鞍,到底是詐尸還是另有隱情,我是刑警寧澤趾徽,帶...
    沈念sama閱讀 35,460評(píng)論 5 344
  • 正文 年R本政府宣布续滋,位于F島的核電站,受9級(jí)特大地震影響孵奶,放射性物質(zhì)發(fā)生泄漏疲酌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評(píng)論 3 327
  • 文/蒙蒙 一了袁、第九天 我趴在偏房一處隱蔽的房頂上張望朗恳。 院中可真熱鬧,春花似錦载绿、人聲如沸粥诫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽怀浆。三九已至,卻和暖如春怕享,著一層夾襖步出監(jiān)牢的瞬間执赡,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工函筋, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留沙合,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,819評(píng)論 2 370
  • 正文 我出身青樓跌帐,卻偏偏與公主長(zhǎng)得像灌诅,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子含末,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 作為一個(gè)合格的開發(fā)者猜拾,不要只滿足于編寫了可以運(yùn)行的代碼。而要了解代碼背后的工作原理佣盒;不要只滿足于自己的程序...
    六個(gè)周閱讀 8,441評(píng)論 1 33
  • 前端開發(fā)面試題 面試題目: 根據(jù)你的等級(jí)和職位的變化挎袜,入門級(jí)到專家級(jí),廣度和深度都會(huì)有所增加。 題目類型: 理論知...
    怡寶丶閱讀 2,582評(píng)論 0 7
  • 謝謝作者的文章 非常喜歡 請(qǐng)?jiān)试S收藏盯仪! 博客園首頁博問閃存新隨筆訂閱管理 vue之better-scroll的封裝...
    peng凱閱讀 16,523評(píng)論 2 5
  • 40紊搪、React 什么是React?React 是一個(gè)用于構(gòu)建用戶界面的框架(采用的是MVC模式):集中處理VIE...
    萌妹撒閱讀 1,014評(píng)論 0 1
  • 原教程內(nèi)容詳見精益 React 學(xué)習(xí)指南全景,這只是我在學(xué)習(xí)過程中的一些閱讀筆記耀石,個(gè)人覺得該教程講解深入淺出,比目前大...
    leonaxiong閱讀 2,834評(píng)論 1 18