Maison >interface Web >js tutoriel >Explication détaillée d'exemples de disposition RN

Explication détaillée d'exemples de disposition RN

零下一度
零下一度original
2017-07-18 17:37:04101950parcourir

Props et état
Nous utilisons deux types de données pour contrôler un composant : les props et state.props sont spécifiés dans le composant parent, et une fois spécifiés , Il ne changera pas pendant le cycle de vie du composant spécifié. Pour les données qui doivent changer, nous devons utiliser des états.

De manière générale, vous devez initialiser l'état dans le constructeur (Annotation : il s'agit de la méthode d'écriture ES6, de nombreux premiers exemples ES5 utilisaient la méthode getInitialState pour initialiser l'état, cette approche sera progressivement éliminée), puis appelez la méthode setState lorsqu'une modification est nécessaire.
C'est-à-dire que rafraîchir l'interface utilisateur revient à appeler la méthode setState pour changer l'état du composant.

Unité de largeur et densité de pixels

La largeur de réaction ne prend pas en charge les pourcentages. Il n'est pas nécessaire d'apporter l'unité {largeur : 10} lors du réglage de la largeur. Alors la largeur spécifique représentée par 10 est Combien ?

Je ne sais pas si c'est parce que le site officiel a une documentation incomplète ou parce que je suis aveugle, mais je ne la trouve pas de toute façon, alors faites une expérience et trouvez-la vous-même :

Explication détaillée dexemples de disposition RN

La valeur par défaut est iPhone6. Le résultat du simulateur est :

Explication détaillée dexemples de disposition RN

Nous connaissons la taille de la série iPhone comme indiqué ci-dessous :

Explication détaillée dexemples de disposition RN

Vous pouvez voir l'iphone 6. La largeur est de 375pt, ce qui correspond au 375 ci-dessus. On voit que l'unité de réaction est le pt. Alors, comment obtenir la taille réelle des pixels ? Ceci est très important pour les images haute résolution. Si la taille de mon image est de 100 * 100 px, définissez la largeur sur 100 * 100. La taille sur l'iPhone sera alors floue. La taille d'image requise à ce stade doit être de 100 * pixelRatio.

react fournit un moyen d'obtenir PixelRatio

Explication détaillée dexemples de disposition RN

mise en page flexible

Largeur par défaut

Nous savons que si un div ne définit pas de largeur, il occupera 100% de la largeur par défaut afin de vérifier 100% de ce problème. , nous avons fait trois expériences

  1. Une vue au-dessus du nœud racine, aucune largeur n'est définie

  2. Une vue est définie sur un élément de largeur fixe , aucune largeur n'est définie

  3. Mettez une largeur de vue sur l'élément flex sans définir la largeur

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

Vous pouvez voir le résultat Si la largeur de l'élément flex n'est pas définie, il occupera 100% du conteneur parent.

Centrage horizontal et vertical

Ce qui se fait souvent en CSS est de centrer un texte ou une image horizontalement et verticalement si vous avez utilisé du CSS. Bien sûr, flexbox sait comment utiliser alignItems et justifierContent. Faisons quelques expériences avec la grille React-native

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

. Disposition

Expérience de disposition en grille, la disposition en grille peut répondre à la plupart des besoins de développement quotidiens, donc tant que les spécifications de disposition en grille sont respectées, la flexibilité de React peut être prouvée La disposition peut répondre besoins normaux de développement

Grille divisée à parts égales

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

La gauche le côté est fixe, le côté droit est fixe et la disposition flexible du milieu

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

Grilles imbriquées
Habituellement, la grille n'est pas une couche et les conteneurs de mise en page sont superposés au sein d'une seule couche, donc la disposition de la grille dans le monde réel doit être vérifiée

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

Heureusement, je n'ai pas tout gâché. Vous pouvez voir la relation imbriquée dans l'image ci-dessus. Aussi complexe que possible. c'est (j'ai également ajouté un ScrollView puis imbriqué toute la structure), il n'y a aucun problème avec l'imbrication des mises en page multicouches.

Mise en page de l'image

Nous devons d'abord savoir que l'image a un accès en mode stretch

Découvrez quels modes sont disponibles

Explication détaillée dexemples de disposition RN

Essayez d'utiliser ces modes

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

100px de hauteur, vous pouvez voir que l'image s'adapte à 100 de hauteur et de largeur plein écran, et que l'arrière-plan est centré et adapté pour ne pas s'étirer mais il est tronqué, ce qui constitue la couverture.

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

le conteneur en mode conteneur s'adapte entièrement aux images, et les images s'adaptent à la largeur et à la hauteur

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

le mode couverture est le même que le mode hauteur 100 px

Explication détaillée dexemples de disposition RN

1Explication détaillée dexemples de disposition RN

l'image en mode étirement est étirée pour s'adapter à l'écran

Explication détaillée dexemples de disposition RN

1Explication détaillée dexemples de disposition RN

Je l'ai essayé au hasard et j'ai constaté que lorsque la hauteur est définie sur le conteneur parent, l'image sera fléchie et ce sera équivalent au mode couverture

Positionnement absolu et positionnement relatif

Explication détaillée dexemples de disposition RN

1Explication détaillée dexemples de disposition RN

La différence avec le standard CSS est que l'élément Le conteneur n'a pas besoin de définir la position : 'absolu|relatif'

Explication détaillée dexemples de disposition RN

<.>1Explication détaillée dexemples de disposition RNVous pouvez voir qu'il est relativement facile de faire correspondre la marge. (J'avais aussi peur de ne pas pouvoir faire correspondre la marge, alors je l'ai testé :-:)

rembourrage et margeNous savons pour distinguer les éléments en ligne dans les éléments CSS et les éléments de bloc, car React-Native implémente un très petit sous-ensemble CSS. Expérimentons ensuite l'utilisation du remplissage et de la marge sur les éléments en ligne et non en ligne.

rembourrage

Explication détaillée dexemples de disposition RN

Explication détaillée dexemples de disposition RN

La configuration du remplissage sur la vue s'est déroulée sans aucun problème. Mais si vous définissez un remplissage sur l'élément en ligne, vous trouverez l'erreur ci-dessus. paddingTop et paddingBottom sont compressés dans marginBottom. Logiquement parlant, le texte ne doit pas être complété. Mais un tel problème existe, vous pouvez donc le marquer.

marge

Explication détaillée dexemples de disposition RN

1Explication détaillée dexemples de disposition RN

Nous savons que pour les éléments en ligne, définissez margin-left et margin -right est valide, top et bottom ne sont pas censés prendre effet, mais comme vous pouvez le voir sur les résultats de l'image ci-dessus, ils prennent réellement effet. Alors maintenant, je pense que l'élément Text doit être compris comme un bloc qui ne peut pas être défini avec un remplissage.

Oubliez ça, ne devinez pas. Voyons ce que dit la documentation officielle à propos de Text

Explication détaillée dexemples de disposition RN

C'est-à-dire que si l'élément Text est à l'intérieur de Text, il peut être considéré comme en ligne. S'il est seul dans la vue, il s'agit d'un bloc.

Ce qui suit étudiera spécifiquement la mise en page liée au texte

Élément de texte

Nous devons d'abord considérer ce que nous voulons pour l'élément Texte De quelles fonctions disposez-vous ou quelles fonctions souhaitez-vous vérifier :

  1. Le texte peut-il être automatiquement renvoyé à la ligne ?

  2. ellipse de débordement ?

  3. Est-il possible de définir des styles pour certains textes, tels que des balises telles que l'attribut de style span

Expérience 1, 2, 3

Explication détaillée dexemples de disposition RN

À en juger par les résultats, 1 , 2 et 3 sont vérifiés. Mais je ne sais pas si vous avez trouvé le problème, pourquoi y a-t-il autant d'espace en bas et aucun réglage en hauteur. J'ai supprimé la ligne de code numberOfLines={5}, et l'effet est le suivant : Explication détaillée dexemples de disposition RN

1Explication détaillée dexemples de disposition RN

Donc en fait, cet espace est ouvert par du texte, mais le texte est numberOfLines ={5} Il a été intercepté, mais l'espace restant est toujours là. Je suppose que c'est un bug.

En fait, dans le document officiel, la phrase numberOfLines={5} est placée sur l'élément Text du texte long, c'est-à-dire sur le sous-texte. Le résultat réel est que cela ne prend pas effet. Cela devrait être un autre bug.

1Explication détaillée dexemples de disposition RNQuelle est l'implémentation spécifique de l'élément sous-texte de l'élément Texte ? Je pense que ce produit aura de nombreux bugs

En coulisses, cela va être converti en un plat

NSAttributedString qui contient les informations suivantes. Ce genre de bug peut être expliqué.

Explication détaillée dexemples de disposition RN

Héritage de style de texte

En fait, l'héritage de style n'existe pas dans React-native, mais pour le texte à l'intérieur du texte element Élément, comme le montre l'exemple ci-dessus, il y a un héritage. Puisqu’il y a héritage, le problème se pose !

Explication détaillée dexemples de disposition RNHérite-t-il de la valeur du texte le plus externe ou hérite-t-il de la valeur du texte parent ?

1Explication détaillée dexemples de disposition RN

De ce fait, on constate qu'il hérite directement du Texte père.

Résumé

  1. la largeur de réaction est basée sur les unités pt Vous pouvez utiliser les dimensions pour obtenir la largeur et la hauteur, et PixelRatio pour obtenir la densité. Si vous souhaitez utiliser des pourcentages, vous pouvez la calculer manuellement en obtenant la largeur de l'écran.

  2. mise en page basée sur Flex

    1. la largeur par défaut de la vue est de 100 %

    2. horizontal Utilisez alignItems pour le centrage et justifierContent pour le centrage vertical

    3. Sur la base de flex, les exigences du système de grille existant peuvent être réalisées et la grille peut être imbriquée de différentes manières sans bugs

  3. Mise en page de l'image

    1. Utilisez Image.resizeMode pour adapter la mise en page de l'image, y compris contenir, couvrir, étirer

    2. Le mode par défaut n'est pas défini, ce qui est égal au mode couverture

    3. le mode contenir s'adapte à la largeur et à la hauteur, donnez simplement la valeur de la hauteur

    4. couvrir le récipient, mais il interceptera

    5. s'étirera pour remplir le récipient, s'étirera

  4. position

    1. Le positionnement est relatif à l'élément parent. L'élément parent n'a pas besoin de définir la position

    2. Il y aura un bug. lorsque le remplissage est défini sur l'élément Text. Tout le remplissage devient marginBottom

  5. Élément de texte

    1. Le texte doit être placé à l'intérieur de l'élément de texte

    2. Les éléments de texte peuvent être imbriqués les uns dans les autres et il existe une relation d'héritage de style

    3. numberOfLines doit être placé sur l'élément de texte le plus à l'extérieur, et bien que le texte est intercepté, il prend toujours de la place

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn