回答:
numberOfLinesを使用する
https://rnplay.org/plays/ImmKkA/edit
または、行ごとの最大文字数を知っている、または計算できる場合は、JS部分文字列を使用できます。
<Text>{ ((mytextvar).length > maxlimit) ?
(((mytextvar).substring(0,maxlimit-3)) + '...') :
mytextvar }
</Text>
numberOfLines
パラメーターを使用しますText
。<Text numberOfLines={1}>long long long long text<Text>
生成されます:
long long long…
(あなたが短い幅のコンテナを持っていると仮定します。)
ellipsizeMode
パラメータを使用して、省略記号をhead
またはに移動しますmiddle
。tail
デフォルト値です。<Text numberOfLines={1} ellipsizeMode='head'>long long long long text<Text>
生成されます:
…long long text
注:Text
成分も含むべきであるstyle={{ flex: 1 }}
省略記号は、そのコンテナのサイズに印加相対する必要がある場合。行レイアウトなどに役立ちます。
ellipsizeModeとnumberOfLinesを使用できます。例えば
<Text ellipsizeMode='tail' numberOfLines={2}>
This very long text should be truncated with dots in the beginning.
</Text>
<View
style={{
flexDirection: 'row',
padding: 10,
}}
>
<Text numberOfLines={5} style={{flex:1}}>
This is a very long text that will overflow on a small device This is a very
long text that will overflow on a small deviceThis is a very long text that
will overflow on a small deviceThis is a very long text that will overflow
on a small device
</Text>
</View>
const styles = theme => ({
contentClass:{
overflow: 'hidden',
textOverflow: 'ellipsis',
display: '-webkit-box',
WebkitLineClamp:1,
WebkitBoxOrient:'vertical'
}
})
render () {
return(
<div className={classes.contentClass}>
{'content'}
</div>
)
}