2017-02-11 209 views
0

下面,調用things()不會呈現任何東西。如果我註釋掉thing(),並且取消註釋它下面的代碼(語義上與函數thing()相同),我會看到顯示的行。爲什麼這是不同的行爲?

爲什麼行爲不同?

function things(){ 
    return (   
      <tbody> 
      <tr> 
       <td><button type="button" className="btn btn-default btn-sm" onClick={this.unwatch}> 
       <span className="glyphicon glyphicon glyphicon-plus" aria-hidden="true"></span> 
       </button></td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{this.props.stock.symbol}</td>     
       <td className={lastClass}>{this.props.stock.last}</td> 
       <td className={changeClass}>{this.props.stock.change} <span className={iconClass} aria-hidden="true"></span></td> 
       <td>{this.props.stock.high}</td> 
       <td>{this.props.stock.low}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
      </tr> 
      </tbody>      
     );   
} 

var StockRow = React.createClass({ 
    unwatch: function() { 
     this.props.unwatchStockHandler(this.props.stock.symbol); 
    }, 
    render: function() { 
     var lastClass = '', 
      changeClass = 'change-positive', 
      iconClass = 'glyphicon glyphicon-triangle-top'; 
     if (this.props.stock === this.props.last) { 
      lastClass = this.props.stock.change < 0 ? 'last-negative' : 'last-positive'; 
     } 
     if (this.props.stock.change < 0) { 
      changeClass = 'change-negative'; 
      iconClass = 'glyphicon glyphicon-triangle-bottom'; 
     } 

     things(); // this doesn't work. Uncomment below does work.Why? 

     /* 
     return (   
      <tbody> 
      <tr> 
       <td><button type="button" className="btn btn-default btn-sm" onClick={this.unwatch}> 
       <span className="glyphicon glyphicon glyphicon-plus" aria-hidden="true"></span> 
       </button></td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{this.props.stock.symbol}</td>     
       <td className={lastClass}>{this.props.stock.last}</td> 
       <td className={changeClass}>{this.props.stock.change} <span className={iconClass} aria-hidden="true"></span></td> 
       <td>{this.props.stock.high}</td> 
       <td>{this.props.stock.low}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
       <td>{}</td> 
      </tr> 
      </tbody>      
     ); 
     */  
    } 
}); 
+2

return語句? –

+0

這是因爲當你調用東西的時候,這些東西被返回來在StockRow中渲染,但只是坐在那裏,什麼都不做。做'返回東西()'。 – Li357

+0

它在語義上不相同:'things()'不返回值。這是預期的行爲 – aarosil

回答

2

把東西放在函數內部類,並使用它像這樣: return <div>{this.things()}</div>它會奏效。

檢查該工作fiddlehttps://jsfiddle.net/455184rh/

+0

不起作用... – Ivan

+0

檢查小提琴它的工作情況檢查控制檯錯誤,如果它失敗的任何部分它將記錄錯誤 –

+0

已經有一個包含表格,所以你在示例中的附加表格是不正確的。我需要代碼如圖所示。 – Ivan

1

而不是使用things()這將只是把數據在那裏,使用回報的東西()將從類返回的數據。

return (things()); 
+0

Doesn不工作:-( – Ivan

+0

確定用括號括起來 – owaishanif786

+0

不起作用... – Ivan