React Native为<text>字段中的单个单词添加粗体或斜体

时间:2016-03-01 08:41:13

标签: react-native

如何在文本字段中以粗体或斜体显示单个单词?有点像这样:

<Text>This is a sentence <b>with</b> one word in bold</Text>

如果我为粗体字符创建一个新的文本字段,它会将它分成另一行,这样肯定不是这样做的。这就像创建一个&lt; p>标签内&lt; p>标记只是为了使一个单词加粗。

13 个答案:

答案 0 :(得分:134)

您可以像容器一样使用<Text>作为其他文本组件。 这是一个例子:

...
<Text>
  <Text>This is a sentence</Text>
  <Text style={{fontWeight: "bold"}}> with</Text>
  <Text> one word in bold</Text>
</Text>
...

这是example

答案 1 :(得分:49)

为了更像网络的感觉:

const B = (props) => <Text style={{fontWeight: 'bold'}}>{props.children}</Text>
<Text>I am in <B>bold</B> yo.</Text>

答案 2 :(得分:6)

您可以使用https://www.npmjs.com/package/react-native-parsed-text

&#13;
&#13;
import ParsedText from 'react-native-parsed-text';
 
class Example extends React.Component {
  static displayName = 'Example';
 
  handleUrlPress(url) {
    LinkingIOS.openURL(url);
  }
 
  handlePhonePress(phone) {
    AlertIOS.alert(`${phone} has been pressed!`);
  }
 
  handleNamePress(name) {
    AlertIOS.alert(`Hello ${name}`);
  }
 
  handleEmailPress(email) {
    AlertIOS.alert(`send email to ${email}`);
  }
 
  renderText(matchingString, matches) {
    // matches => ["[@michel:5455345]", "@michel", "5455345"]
    let pattern = /\[(@[^:]+):([^\]]+)\]/i;
    let match = matchingString.match(pattern);
    return `^^${match[1]}^^`;
  }
 
  render() {
    return (
      <View style={styles.container}>
        <ParsedText
          style={styles.text}
          parse={
            [
              {type: 'url',                       style: styles.url, onPress: this.handleUrlPress},
              {type: 'phone',                     style: styles.phone, onPress: this.handlePhonePress},
              {type: 'email',                     style: styles.email, onPress: this.handleEmailPress},
              {pattern: /Bob|David/,              style: styles.name, onPress: this.handleNamePress},
              {pattern: /\[(@[^:]+):([^\]]+)\]/i, style: styles.username, onPress: this.handleNamePress, renderText: this.renderText},
              {pattern: /42/,                     style: styles.magicNumber},
              {pattern: /#(\w+)/,                 style: styles.hashTag},
            ]
          }
          childrenProps={{allowFontScaling: false}}
        >
          Hello this is an example of the ParsedText, links like http://www.google.com or http://www.facebook.com are clickable and phone number 444-555-6666 can call too.
          But you can also do more with this package, for example Bob will change style and David too. foo@gmail.com
          And the magic number is 42!
          #react #react-native
        </ParsedText>
      </View>
    );
  }
}
 
const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
 
  url: {
    color: 'red',
    textDecorationLine: 'underline',
  },
 
  email: {
    textDecorationLine: 'underline',
  },
 
  text: {
    color: 'black',
    fontSize: 15,
  },
 
  phone: {
    color: 'blue',
    textDecorationLine: 'underline',
  },
 
  name: {
    color: 'red',
  },
 
  username: {
    color: 'green',
    fontWeight: 'bold'
  },
 
  magicNumber: {
    fontSize: 42,
    color: 'pink',
  },
 
  hashTag: {
    fontStyle: 'italic',
  },
 
});
&#13;
&#13;
&#13;

答案 3 :(得分:4)

它不是在要求的文本字段中,而是将单独的文本元素包装到视图中将提供所需的输出。如果您不想仅将样式设置为几个文本,就可以在项目中添加另一个库。

<View style={{flexDirection: 'row'}}>
 <Text style={{fontWeight: '700', marginRight: 5}}>Contact Type:</Text>
 <Text>{data.type}</Text>
</View>

结果将如下

enter image description here

答案 4 :(得分:3)

使用此react native library

安装

npm install react-native-htmlview --save

基本用法

 import React from 'react';
 import HTMLView from 'react-native-htmlview';

  class App extends React.Component {
  render() {
   const htmlContent = 'This is a sentence <b>with</b> one word in bold';

  return (
   <HTMLView
     value={htmlContent}
   />    );
  }
}

支持几乎所有的html标签。

用于更高级的用法,例如

  1. 链接处理
  2. 自定义元素渲染
  3. 查看此ReadMe

答案 5 :(得分:1)

现在无法嵌套文本组件,但是您可以将文本包装在这样的视图中:

<View style={{flexDirection: 'row', flexWrap: 'wrap'}}>
    <Text>
        {'Hello '}
    </Text>
    <Text style={{fontWeight: 'bold'}}>
        {'this is a bold text '}
    </Text>
    <Text>
        and this is not
    </Text>
</View>

我使用了方括号内的字符串来强制单词之间的间隔,但您也可以使用marginRight或marginLeft来实现。希望对您有所帮助。

答案 6 :(得分:1)

enter image description here

我是react-native-spannable-string

的维护者

具有自定义样式的嵌套<Text/>组件效果很好,但可维护性很低。

我建议您使用此库构建类似这样的可扩展字符串。

SpannableBuilder.getInstance({ fontSize: 24 })
    .append('Using ')
    .appendItalic('Italic')
    .append(' in Text')
    .build()

答案 7 :(得分:0)

粗体:

<Text>
  <Text>This is a sentence</Text>
  <Text style={{fontWeight: "bold"}}> with</Text>
  <Text> one word in bold</Text>
</Text>

斜体文本:

<Text>
  <Text>This is a sentence</Text>
  <Text style={{fontStyle: "italic"}}> with</Text>
  <Text> one word in italic</Text>
</Text>

答案 8 :(得分:0)

例如!

const TextBold = (props) => <Text style={{fontWeight: 'bold'}}>Text bold</Text>

<Text> 123<TextBold/> </Text>

答案 9 :(得分:0)

<Text>
    <Text style={{fontWeight: "bold"}}>bold</Text>
    normal text
    <Text style={{fontStyle: "italic"}}> italic</Text>
</Text>

答案 10 :(得分:0)

您还可以在另一个Text标签内放置一个Text标签。第二个文本标签将继承第一个文本标签的样式,但您仍可以独立于其父样式进行样式设置。

<Text style={styles.bold}>Level: 
    <Text style={styles.normal}>Easy</Text>
</Text>

//in your stylesheet...

  bold: {
    fontSize: 25,
    fontWeight: "bold",
    color: "blue",
  },
  normal: {
  // will inherit size and color attributes
    fontWeight: "normal",
  }

答案 11 :(得分:-1)

<Text style={{fontWeight: "500"}}> bla bla</Text>

答案 12 :(得分:-1)

您可以仅使用所需样式嵌套Text组件。该样式将与第一个Text组件中已定义的样式一起应用。

示例:

 <Text style={styles.paragraph}>
   Trouble singing in. <Text style={{fontWeight: "bold"}}> Resolve</Text>
 </Text>