Heim >Web-Frontend >js-Tutorial >Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

零下一度
零下一度Original
2017-07-18 17:37:04101929Durchsuche

Props und Status
Wir verwenden zwei Arten von Daten, um eine Komponente zu steuern: Props und State.props werden in der übergeordneten Komponente angegeben und einmal angegeben , Es wird sich während des Lebenszyklus der angegebenen Komponente nicht ändern. Für Daten, die sich ändern müssen, müssen wir Zustände verwenden.

Im Allgemeinen müssen Sie den Status im Konstruktor initialisieren (Anmerkung: Dies ist die ES6-Schreibweise. Viele frühe ES5-Beispiele verwendeten die getInitialState-Methode zum Initialisieren des Status. Dieser Ansatz wird nach und nach eliminiert.) und rufen Sie dann die setState-Methode auf, wenn eine Änderung erforderlich ist.
Das heißt, zum Aktualisieren der Benutzeroberfläche muss die setState-Methode aufgerufen werden, um den Status der Komponente zu ändern.

Breiteneinheit und Pixeldichte

Die Breite von React unterstützt keine Prozentsätze. Beim Festlegen der Breite muss die Einheit {width: 10} nicht angegeben werden. Dann ist die durch 10 dargestellte spezifische Breite Wie groß?

Ich weiß nicht, ob es an der unvollständigen Dokumentation auf der offiziellen Website liegt oder daran, dass ich blind bin, aber ich kann es sowieso nicht finden, also machen Sie ein Experiment und finden Sie es selbst:

Ausführliche Erläuterung von Beispielen für das RN-Layout

Der Standardwert ist iPhone6. Das Simulatorergebnis ist:

Ausführliche Erläuterung von Beispielen für das RN-Layout

Wir kennen die Größe der iPhone-Serie wie unten gezeigt:

Ausführliche Erläuterung von Beispielen für das RN-Layout

Sie können sehen, dass die Breite des iPhone 6 375 pt beträgt, was den 375 oben entspricht. Es ist ersichtlich, dass die Reaktionseinheit pt ist. Wie erhält man also die tatsächliche Pixelgröße? Dies ist sehr wichtig für hochauflösende Bilder. Wenn meine Bildgröße 100 * 100 Pixel beträgt, stellen Sie die Breite auf 100 * 100 ein. Dann ist die Größe auf dem iPhone unscharf. Die zu diesem Zeitpunkt erforderliche Bildgröße sollte 100 * pixelRatio betragen.

React bietet eine Möglichkeit, PixelRatio zu erhalten

Ausführliche Erläuterung von Beispielen für das RN-Layout

Flex-Layout

Standardbreite

Wir wissen, dass ein Div, wenn es keine Breite festlegt, standardmäßig 100 % der Breite einnimmt, um 100 % dieses Problems zu überprüfen , wir haben drei Experimente durchgeführt

  1. Eine Ansicht über dem Wurzelknoten, keine Breite ist festgelegt

  2. Eine Ansicht ist auf ein Element mit fester Breite festgelegt , es ist keine Breite festgelegt

  3. Fügen Sie eine Ansichtsbreite auf das Flex-Element ein, ohne die Breite festzulegen

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

Sie können das Ergebnis sehen. Wenn die Breite des Flex-Elements nicht festgelegt ist, nimmt es 100 % des übergeordneten Containers ein.

Horizontale und vertikale Zentrierung

Was in CSS oft gemacht wird, ist, einen Text oder ein Bild horizontal und vertikal zu zentrieren Natürlich weiß Flexbox, wie man alignItems und justifyContent verwendet. Lassen Sie uns einige Experimente mit dem React-Native-Grid durchführen Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

Rasterlayout-Experiment: Das Rasterlayout kann die meisten täglichen Entwicklungsanforderungen erfüllen. Solange die Spezifikationen des Rasterlayouts erfüllt sind, kann die Flexibilität der Reaktion nachgewiesen werden. Das Layout kann erfüllt werden normale EntwicklungsbedürfnisseAusführliche Erläuterung von Beispielen für das RN-Layout

Gleichgeteiltes Gitter


Die Linke Seite ist fixiert, die rechte Seite ist fixiert und das mittlere Flex-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

Verschachtelte Gitter
Normalerweise besteht das Gitter nicht aus einer Ebene, und die Layoutcontainer sind innerhalb einer Ebene geschichtet, daher muss das Gitterlayout unter der realen Welt überprüft werden

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

Zum Glück habe ich es im Bild oben nicht vermasselt Es gibt kein Problem mit der Verschachtelung mehrschichtiger Layouts (ich habe auch eine ScrollView hinzugefügt und dann die gesamte Struktur verschachtelt).

Bildlayout

Zuerst müssen wir wissen, dass das Bild einen Stretch-Modus hat. Zugriff

Finden Sie heraus, welche Modi verfügbar sind

Ausführliche Erläuterung von Beispielen für das RN-Layout

Versuchen Sie, diese Modi zu verwenden

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout100 Pixel Höhe, Sie können sehen, dass sich das Bild an die 100 Pixel Höhe und die volle Bildschirmbreite anpasst und der Hintergrund zentriert und so angepasst ist, dass er nicht gedehnt wird ist aber abgeschnitten, was das Cover darstellt.

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-LayoutDer Container im Containermodus nimmt Bilder vollständig auf und Bilder passen sich der Breite und Höhe an

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-LayoutDer Cover-Modus ist derselbe wie der 100-Pixel-Höhenmodus.

Ausführliche Erläuterung von Beispielen für das RN-Layout

1Ausführliche Erläuterung von Beispielen für das RN-LayoutDas Bild im Stretch-Modus wird gestreckt um auf den Bildschirm zu passen

Ausführliche Erläuterung von Beispielen für das RN-Layout

1Ausführliche Erläuterung von Beispielen für das RN-Layout Ich habe es zufällig ausprobiert und festgestellt, dass das Bild gebeugt wird, wenn die Höhe auf den übergeordneten Container eingestellt ist und es entspricht dem Cover-Modus

Absolute Positionierung und relative Positionierung

Ausführliche Erläuterung von Beispielen für das RN-Layout

1Ausführliche Erläuterung von Beispielen für das RN-LayoutDer Unterschied zum CSS-Standard besteht darin, dass das Element Der Container muss keine Position festlegen:

Ausführliche Erläuterung von Beispielen für das RN-Layout

1Ausführliche Erläuterung von Beispielen für das RN-LayoutSie sehen, dass es relativ einfach ist, den Rand anzupassen. (Ich hatte auch Angst, dass ich den Rand nicht anpassen könnte, also habe ich es getestet:-:)

Auffüllung und RandWir wissen es um Inline-Elemente und Blockelemente in CSS zu unterscheiden, da React-Native eine sehr kleine CSS-Teilmenge implementiert. Dann experimentieren wir mit der Verwendung von Polsterung und Rand für Inline- und Nicht-Inline-Elemente.

Polsterung

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

Das Einrichten der Polsterung am View verlief reibungslos und ohne Probleme. Wenn Sie jedoch den Abstand für das Inline-Element festlegen, wird der obige Fehler angezeigt. paddingTop und paddingBottom werden in marginBottom gequetscht. Logischerweise sollte Text nicht aufgefüllt werden. Ein solches Problem existiert jedoch, daher können Sie dieses Problem markieren.

Margin

Ausführliche Erläuterung von Beispielen für das RN-Layout

Ausführliche Erläuterung von Beispielen für das RN-Layout

Wir wissen, dass für Inline-Elemente margin-left und margin festgelegt werden -right ist gültig, oben und unten sollen nicht wirksam werden, aber wie Sie anhand der Ergebnisse im Bild oben sehen können, werden sie tatsächlich wirksam. Jetzt bin ich der Meinung, dass das Textelement als Block verstanden werden sollte, der nicht mit Auffüllung gesetzt werden kann.

Vergiss es, rate nicht. Mal sehen, was die offizielle Dokumentation über Text sagt

Ausführliche Erläuterung von Beispielen für das RN-Layout

Das heißt, wenn sich das Textelement in Text befindet, ist es Kann als Inline betrachtet werden, wenn es allein in der Ansicht ist.

Im Folgenden wird speziell das textbezogene Layout untersucht

Textelement

Zuerst müssen wir überlegen, was wir wollen für das Textelement Welche Funktionen haben Sie oder welche Funktionen möchten Sie überprüfen:

  1. Kann der Text automatisch umgebrochen werden?

  2. Überlaufellipse?

  3. Ist es möglich, Stile für einige Texte festzulegen, z. B. Tags wie das Stilattribut

Experiment 1, 2, 3

Ausführliche Erläuterung von Beispielen für das RN-Layout

Den Ergebnissen nach zu urteilen, 1 , 2 und 3 werden überprüft. Aber ich weiß nicht, ob Sie das Problem gefunden haben, warum ist unten so viel Platz und keine Höheneinstellung? Ich habe die Codezeile numberOfLines={5} entfernt und der Effekt ist wie folgt: Ausführliche Erläuterung von Beispielen für das RN-Layout

1Ausführliche Erläuterung von Beispielen für das RN-Layout

Dieser Raum wird also tatsächlich durch Text geöffnet, aber der Text ist numberOfLines ={5} Es wurde abgefangen, aber der verbleibende Speicherplatz ist noch vorhanden. Ich denke, das ist ein Fehler.

Tatsächlich wird im offiziellen Dokument der Satz numberOfLines={5} im Textelement des Langtextes, also im Untertext, platziert. Das tatsächliche Ergebnis ist, dass es nicht wirksam wird. Dies sollte ein weiterer Fehler sein.

1Ausführliche Erläuterung von Beispielen für das RN-LayoutWas ist die spezifische Implementierung des Untertextelements des Textelements? Ich bin der Meinung, dass dieses Produkt viele Fehler aufweisen wird. Siehe den offiziellen Artikel

Hinter den Kulissen wird dies in einen flachen

NSAttributedString umgewandelt, der die folgenden Informationen enthält. Diese Art von Fehler kann erklärt werden.

Ausführliche Erläuterung von Beispielen für das RN-Layout

Textstilvererbung

Tatsächlich gibt es in React-native keine Stilvererbung, sondern für den Text innerhalb des Textes element Element, wie aus dem obigen Beispiel ersichtlich ist, gibt es eine Vererbung. Da es eine Vererbung gibt, entsteht das Problem! Ausführliche Erläuterung von Beispielen für das RN-Layout

Wird der Wert des äußersten Texts vererbt oder der Wert des übergeordneten Texts?

1Ausführliche Erläuterung von Beispielen für das RN-Layout

Daraus ist ersichtlich, dass es den Vatertext direkt erbt.

Zusammenfassung

  1. Die Reaktionsbreite basiert auf pt-Einheiten. Sie können Abmessungen verwenden, um die Breite und Höhe zu ermitteln. und PixelRatio, um die Dichte zu ermitteln. Wenn Sie Prozentsätze verwenden möchten, können Sie diese manuell berechnen, indem Sie die Bildschirmbreite ermitteln.

  2. Flex-basiertes Layout

    1. Die Standardbreite der Ansicht beträgt 100 %

    2. horizontal Verwenden Sie alignItems zum Zentrieren und justifyContent zum vertikalen Zentrieren

    3. Basierend auf Flex können die bestehenden Anforderungen an das Rastersystem realisiert werden und das Raster kann auf verschiedene Arten ohne Fehler verschachtelt werden

  3. Bildlayout

    1. Verwenden Sie Image.resizeMode, um das Bildlayout anzupassen, einschließlich Einschließen, Abdecken, Strecken

    2. Der Standardmodus ist nicht festgelegt, was dem Cover-Modus entspricht

    3. Contain-Modus passt sich der Breite und Höhe an, geben Sie einfach den Höhenwert ein

    4. Den Behälter abdecken, aber er wird

    5. Strecken abfangen, um den Behälter zu füllen, Strecken

  4. Position

    1. Die Positionierung erfolgt relativ zum übergeordneten Element.

    2. Es tritt ein Fehler auf Der Abstand wird für das Textelement festgelegt. Alle Polsterungen werden zu marginBottom

  5. Textelement

    1. Der Text muss innerhalb des Textelements platziert werden

    2. Textelemente können ineinander verschachtelt werden, und es besteht eine Stilvererbungsbeziehung

    3. numberOfLines muss auf dem äußersten Textelement platziert werden, und zwar trotz des Textes abgefangen wird, wird es immer noch Platz beanspruchen

Das obige ist der detaillierte Inhalt vonAusführliche Erläuterung von Beispielen für das RN-Layout. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn