Comment définir un raccourci de marge/remplissage dans React Native?
CSS
margin: 10px 20px;
Lorsque vous utilisez des styles natifs React Native, vous pouvez réécrire votre css ci-dessus pour
{ marginVertical: 10, marginHorizontal: 20 }
Sinon, la syntaxe ci-dessus peut être obtenue si vous utilisez quelque chose comme styled-components , qui utilise css-to-react-native sous le capot.
J'ai créé cette fonction d'assistance dans le projet précédent:
const getShortHand = (style: string, ...values) => {
if (values.length === 1) {
return { [style]: values[0] }
}
const _genCss = (...values) => ({
[style + 'Top']: values[0],
[style + 'Right']: values[1],
[style + 'Bottom']: values[2],
[style + 'Left']: values[3],
})
if (values.length === 2) {
return _genCss(values[0], values[1], values[0], values[1])
}
if (values.length === 3) {
return _genCss(values[0], values[1], values[2], values[1])
}
return _genCss(values[0], values[1], values[2], values[3])
}
export const padding = (...values: Array<number | string>) => getShortHand('padding', ...values)
export const margin = (...values: Array<number | string>) => getShortHand('margin', ...values)
L'utilisation est similaire avec le raccourci css normal:
const styles = StyleSheet.create({
button: {
...padding(12, 20),
},
}