React Native doesn't implement CSS but instead relies on JavaScript to let you style your application. This has been a controversial decision and you can read through those slides for the rationale behind it.
The way to declare styles in React Native is the following:
StyleSheet.create
construct is optional but provides some key advantages. It ensures that the values are immutable and opaque by transforming them into plain numbers that reference an internal table. By putting it at the end of the file, you also ensure that they are only created once for the application and not on every render.
All the attribute names and values are a subset of what works on the web. For layout, React Native implements Flexbox.
All the core components accept a style attribute.
They also accept an array of styles.
The behavior is the same as Object.assign
: in case of conflicting values, the one from the right-most element will have precedence and falsy values like false
, undefined
and null
will be ignored. A common pattern is to conditionally add a style based on some condition.
Finally, if you really have to, you can also create style objects in render, but they are highly discouraged. Put them last in the array definition.
In order to let a call site customize the style of your component children, you can pass styles around. Use View.propTypes.style
and Text.propTypes.style
in order to make sure only styles are being passed.
You can checkout latest support of CSS Properties in following Links.