The styleName
attribute and syntax are based on babel-plugin-react-css-modules.
This example only shows how to setup CSS support using the CSS transformer. Have a look at the setup documentation if you need PostCSS, Sass, Less or Stylus support (you need to use a different transformer and file extensions).
Following libraries are needed:
- react-native-css-transformer - Transforms CSS to a React Native compatible style object and handles live reloading
- babel-plugin-react-native-platform-specific-extensions - Transforms ES6
import
statements to platform specificrequire
statements if the platform specific files exist on disk. - babel-plugin-react-native-stylename-to-style - Transforms special
styleName
property tostyle
property.
Make sure that you have react-native-cli
installed (npm install -g react-native-cli
) and XCode (for iOS development) / Android Studio (for Android development) installed and working.
- Go to "Building Projects with Native Code" tab and follow the guide: https://facebook.github.io/react-native/docs/getting-started.html
e.g.
react-native init AwesomeProject
cd AwesomeProject
Start packager:
yarn start
Run project on iOS simulator:
react-native run-ios
yarn add babel-plugin-react-native-stylename-to-style babel-plugin-react-native-platform-specific-extensions react-native-css-transformer --dev
.babelrc
(or babel.config.js
)
{
"presets": ["module:metro-react-native-babel-preset"],
"plugins": [
[
"react-native-stylename-to-style",
{
"extensions": ["css"]
}
],
[
"react-native-platform-specific-extensions",
{
"extensions": ["css"]
}
]
]
}
.babelrc
{
"presets": ["react-native"],
"plugins": [
[
"react-native-stylename-to-style",
{
"extensions": ["css"]
}
],
[
"react-native-platform-specific-extensions",
{
"extensions": ["css"]
}
]
]
}
babel.config.js
(older Expo versions use .babelrc
)
module.exports = function (api) {
api.cache(true);
return {
presets: ["babel-preset-expo"],
plugins: [
[
"react-native-stylename-to-style",
{
extensions: ["css"],
},
],
[
"react-native-platform-specific-extensions",
{
extensions: ["css"],
},
],
],
};
};
Add this to metro.config.js
in your project's root (create the file if you don't have one already):
const { getDefaultConfig } = require("metro-config");
module.exports = (async () => {
const {
resolver: { sourceExts },
} = await getDefaultConfig();
return {
transformer: {
babelTransformerPath: require.resolve("react-native-css-transformer"),
},
resolver: {
sourceExts: [...sourceExts, "css"],
},
};
})();
If you are using Expo, you also need to add this to app.json
:
{
"expo": {
"packagerOpts": {
"config": "metro.config.js",
"sourceExts": ["js", "jsx", "css"]
}
}
}
If you are using React Native without Expo, add this to rn-cli.config.js
in your project's root (create the file if you don't have one already):
module.exports = {
getTransformModulePath() {
return require.resolve("react-native-css-transformer");
},
getSourceExts() {
return ["js", "jsx", "css"];
},
};
If you are using Expo, instead of adding the rn-cli.config.js
file, you need to add this to app.json
:
{
"expo": {
"packagerOpts": {
"sourceExts": ["js", "jsx", "css"],
"transformer": "node_modules/react-native-css-transformer/index.js"
}
}
}
styles.css
:
.container {
flex: 1;
justify-content: center;
align-items: center;
background-color: #f5fcff;
}
.blue-text {
color: blue;
font-size: 30px;
}
Add style import and BlueText
component to App.js
:
import React, { Component } from "react";
import { Text, View } from "react-native";
import "./styles.css";
const BlueText = () => {
return <Text styleName="blue-text">Blue Text</Text>;
};
export default class App extends Component<{}> {
render() {
return (
<View styleName="container">
<BlueText />
</View>
);
}
}
Restart React Native packager and clear it's cache (important) to see the styles that you added.
yarn start --reset-cache