样式文本组件的一部分

时间:2015-12-02 14:50:07

标签: flexbox react-native

我正在努力制作反应原生组件,其中同一组件中的不同单词具有不同的样式。

例如,按钮上有按钮名称和副标题,我希望字幕文字更小。

<Text style={styles.buttonText}>{speciesArry[i].title} {"\n"}       {speciesArry[i].subtitle}</Text>

我需要将字幕包装在自己的组件中,以便我可以设置样式吗?

第二个例子

我有另一个带有文本组件的按钮     绿色 - 最佳选择 我需要&#34;绿色&#34;是绿色的。

1 个答案:

答案 0 :(得分:2)

对于第一个问题,一个带有标题和副标题的按钮,您可以将视图包装在TouchableHighlight中,然后放置多个Text元素以创建标题和副标题:

<TouchableHighlight style={{height:70, backgroundColor: 'blue'}}>
    <View style={{flexDirection: 'column', }}>
        <Text style={{textAlign:'center', color: 'white', fontSize:22, marginTop:10}}>MAIN TEXT</Text>
        <Text style={{textAlign:'center', color: 'white', fontSize:14}}>Subtitle</Text>
    </View>
</TouchableHighlight>

对于第二个问题,在单个文本组件中使用不同的样式,您需要在文本组件中包装文本组件,就像在html中使用span一样:

<Text style={styles.mainStyle}>This text is red, <Text style={styles.blacktext}>this text is black, </Text><Text style={styles.boldgreen}>this text is bold and green!</Text></Text>

上面提供的按钮示例如下所示:

<TouchableHighlight style={{height:70, backgroundColor: 'orange'}}>
    <View style={{ flexDirection: 'row', justifyContent:'center'}}>
        <Text style={{fontSize:18, marginTop: 22}}><Text style={{color: 'green'}}>Green</Text> - best Choice</Text>
     </View>
 </TouchableHighlight>

对于float:正确的问题:在flexbox中没有任何与它完全相同的东西,但有一些非常类似于它的东西:justifyContent:'flex-end'。下面是它的外观,我已经更新了原始项目以反映下面的代码:

<View style={{flexDirection: 'row', justifyContent: 'flex-end'}}>
    <Text>Floating right</Text>
</View>

我已经使用上面的示例here设置了一个完整的工作项目,并粘贴了下面项目的整个代码。希望这可以帮助!

https://rnplay.org/apps/KqE-cA

'use strict';

var React = require('react-native');
var {
  AppRegistry,
  StyleSheet,
  Text,
  View,
  TouchableHighlight,
} = React;

var SampleApp = React.createClass({
  render: function() {
    return (
      <View style={styles.container}>
       <View style={{marginTop:70}}>
            <TouchableHighlight style={{height:70, backgroundColor: 'blue'}}>
                <View style={{flexDirection: 'column', }}>
                <Text style={{textAlign:'center', color: 'white', fontSize:22, marginTop:10}}>MAIN TEXT</Text>
                <Text style={{textAlign:'center', color: 'white', fontSize:14}}>Subtitle</Text>
            </View>
          </TouchableHighlight>
       </View>

       <View style={{marginTop:20}}>
            <Text style={styles.mainStyle}>This text is red, <Text style={styles.blacktext}>this text is black, </Text><Text style={styles.boldgreen}>this text is bold and green!</Text></Text>         
       </View>

       <View style={{marginTop:20}}>
            <TouchableHighlight style={{height:70, backgroundColor: 'orange'}}>
              <View style={{ flexDirection: 'row', justifyContent:'center'}}>
                <Text style={{fontSize:18, marginTop: 22}}><Text style={{color: 'green'}}>Green</Text> - best Choice</Text>
              </View>
            </TouchableHighlight>
       </View>

      </View>
    );
  }
});

var styles = StyleSheet.create({
  container: {
    flex: 1,
  },
  mainStyle: {
    color: 'red'
  },
  blacktext: {
    color: 'black'
  },
  boldgreen: {
    color: 'green',
    fontWeight: 'bold'
  }

});

AppRegistry.registerComponent('SampleApp', () => SampleApp);