React Native -- StyleSheet

StyleSheet样式表来渲染组件的样式,源码如下:

 /* Code quality:
 *
 *  - By moving styles away from the render function,you're making the code
 *  easier to understand.
 *  - Naming the styles is a good way to add meaning to the low level components
 *  in the render function.
 *
 * Performance:
 *
 *  - Making a stylesheet from a style object makes it possible to refer to it
 * by ID instead of creating a new style object every time.
 *  - It also allows to send the style only once through the bridge. All
 * subsequent uses are going to refer an id (not implemented yet).
 */
class StyleSheet {
  static create(obj: {[key: string]: any}): {[key: string]: number} {
    var result = {};
    for (var key in obj) {
      StyleSheetValidation.validateStyle(key,obj);
      result[key] = StyleSheetRegistry.registerStyle(obj[key]);
    }
    return result;
  }
}
创建StyleSheet

var styles = StyleSheet.create({
      container: {
        borderRadius: 4,borderWidth: 0.5,borderColor: '#d6d7da',},title: {
        fontSize: 19,fontWeight: 'bold',activeTitle: {
        color: 'red',});
StyleSheetRegistry.registerStyle(obj[key]);返回的是一个uniqueID,StyleSheet.create返回的每个key对应的 uniqueID,styles存储key以及对应的uniqueID,设置组件属性的时候根据key获取uniqueID,根据uniqueID获取对应的样式。

var styles = {};
var uniqueID = 1;
var emptyStyle = {};


class StyleSheetRegistry {
 static registerStyle(style: Object): number {
  var id = ++uniqueID;
  if (__DEV__) {
   Object.freeze(style);
  }
  styles[id] = style;
  return id;
 }


 static getStyleByID(id: number): Object {
  if (!id) {
   // Used in the style={[condition && id]} pattern,// we want it to be a no-op when the value is false or null
   return emptyStyle;
  }


  var style = styles[id];
  if (!style) {
   console.warn('Invalid style with id `' + id + '`. Skipping ...');
   return emptyStyle;
  }
  return style;
 }
}

使用StyleSheet

<View style={styles.container}>
   <Text style={[styles.title,this.props.isActive && styles.activeTitle]} />
</View>
设置一个样式使用 style = {styles.container}

设置多个样式使用style={[styles.title, this.props.isActive && styles.activeTitle]}不过后面的样式会覆盖前面的样式

相关文章

react 中的高阶组件主要是对于 hooks 之前的类组件来说的,如...
我们上一节了解了组件的更新机制,但是只是停留在表层上,例...
我们上一节了解了 react 的虚拟 dom 的格式,如何把虚拟 dom...
react 本身提供了克隆组件的方法,但是平时开发中可能很少使...
mobx 是一个简单可扩展的状态管理库,中文官网链接。小编在接...
我们在平常的开发中不可避免的会有很多列表渲染逻辑,在 pc ...