suchen
HeimWeb-FrontendCSS-TutorialInvariant und variabel im CSS-Design

Invariant und variabel im CSS-Design

Dec 03, 2016 am 11:23 AM
cssVariable

„Im Laufe des Lebens werden manche Menschen zu Gesichtern und andere zu Lizi. Das hängt alles von der Zeit ab.“ – „Der Großmeister“

Wenn wir die Beziehung zwischen Lizi und Gesicht rekonstruieren, dann sollte HTML das tun Seien Sie verantwortlich. Es geht um das Gesicht, und CSS ist für das Gesicht verantwortlich. Lassen Sie uns über CSS sprechen. Dieses Mal analysieren wir es aus der Perspektive der Variabilität und Unveränderlichkeit.

Eine Interviewfrage

Erstens ist dies eine Interviewfrage. Zweitens habe ich diese Interviewfrage sowieso nie gestellt. Schließlich habe ich vergessen, aus welcher Fabrik die Interviewfrage stammt.

Ich habe die spezifischen Anforderungen vergessen. Die allgemeine Bedeutung ist, dass der Inhalt vertikal im Fenster zentriert sein sollte. Der Text sollte sich nach oben und unten erstrecken , es wird nach oben erweitert, und wenn sich unten mehr Text befindet, wird es nach unten verschoben. Beim Öffnen ist die Größe des Bildes festgelegt, aber die Textgröße ist nicht festgelegt (die rote Linie wurde von mir als Vertikale hinzugefügt). Mittellinie zur besseren Erläuterung). Dabei gehört der Text zum variablen Faktor, während das Bild zum festen Faktor gehört.

Invariant und variabel im CSS-Design

Ideenanalyse

Zunächst sehen wir, dass sich die Bilder hier alle auf derselben horizontalen Linie befinden und die Textmenge keinen Einfluss auf die Bilder haben kann Daher kommen wir zu dem Schluss, dass es möglich ist. Es gibt zwei Lösungen: Die erste besteht darin, den Text normal zu fließen und das Bild absolut zu positionieren. Die zweite Möglichkeit besteht darin, den Text absolut zu positionieren und das Bild in einem normalen Dokument zu fließen.

Zweitens verletzt die Ausdehnungsrichtung des obigen Textes die normale Flussrichtung des Dokuments (normalerweise sollte sie sich mit zunehmendem Text nach unten erstrecken), sodass der Textteil oben eine absolute Positionierung erfordert Der untere Wert ist auf

eingestellt. In Kombination mit den beiden oben genannten Gründen verwenden wir schließlich zunächst die zweite Lösung zum Testen, mit absoluter Positionierung des Textes und normalem Dokumentfluss von Bildern.

Hier verwenden wir die Idee der Disassemblierung im vorherigen Artikel, um die HTML-Struktur wie folgt zu erhalten:

ul.demo
    li
        .text-top
        img.img-center
        .text-bottom

Der Haupt-CSS-Code lautet wie folgt:

.demo{ position:absolute; top: 50%;
} .demo li{ float: left; width: 120px; margin: 0 20px; position: relative;
} .text-top{ position: absolute; bottom: 90px; left: 0;
} .img-center{ margin-top: -34px; width: 120px; height: 68px;
} .text-bottom{ position: absolute; top: 50px;
}

Häufige Beispiele

Content Fluid Layout

Hier ist die Seitenleiste fixiert und der Inhalt ist ein flüssiges Layout mit der verbleibenden Breite. Die Seitenleiste ist ein fester Faktor und der Inhalt ist ein variabler Faktor.

section.section-main
    .inner-center.clearfix
        .main>.content
        aside.aside-right
.main{ float: left; width: 100%;
} .main .content{ margin-right: 320px;
} .aside-right{ float: left; width: 300px; margin-left: -320px;
}

Gemischte Anordnung von Bildern und Text

Es ist immer noch die gleiche gemischte Anordnung von Bildern und Text, aber die Breite ist festgelegt des Textteils ist nicht gesetzt. Der feste Faktor ist die Breite des Bildes und der variable Faktor ist die Breite des Textes.

.imgtext-mix
    a.mix-img-link>img.mix-img
    .mix-text
        h3.mix-tt>a.mix-tt-link
        .mix-intro
.mix-img-link{ float: left; width: 200px; margin-right: 20px;
} .mix-text{ overflow: hidden;
}

Die Breite des Containers ist variabel, aber das Seitenverhältnis ist sicher

Einzelheiten finden Sie unter: So skalieren Sie den Container proportional in CSS, ich habe gewonnen Ich gehe hier nicht auf Details ein. Der konstante Faktor ist das Seitenverhältnis, der variable Faktor ist die Breite.

Variable und Invariante auf dem mobilen Endgerät

Viele Leute, die gerade erst mit der Umgestaltung mobiler Endgeräte beginnen, stellen normalerweise eine Frage: Verwenden alle mobilen Endgeräte Prozentsätze? Tatsächlich kann neben den neuen Einheiten wie rem, vw, vh usw. neben dem Prozentsatz auch px auf dem mobilen Endgerät verwendet werden, was Sie überhaupt nicht denken. Welche Einheit verwendet werden soll, ist das Wichtigste, um die Variable und Unveränderlichkeit zu erfassen. Wenn Sie es gut verstehen, ist die Rekonstruktion eines mobilen Endgeräts tatsächlich dasselbe wie die eines PCs. Wenn Sie es gewohnt sind, auf Ihrem PC eine feste Breite und Höhe festzulegen, werden Sie wahrscheinlich frustriert sein.

Vollbild-Bildlauf

Vollbild, wenn vw noch nicht verfügbar ist, muss es 100 % sein (Vollbild bedeutet hier, dass die Breite den gesamten Bildschirm abdeckt, ohne Höhe).

ul.imgslide
    li*4>img
// float布局
.imgslide{
    width: 400%;
}
.imgslide li{
    width: 25%;
    float: left;
}
// absoulte布局
.imgslide{
    width: 100%;
    height: 100px;
    position: relative;
}
.imgslide li{
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}
.imgslide li:nth-child(n+1){
    transform: translate(100%, 0);
}

Gemischte Bild- und Textliste

Immer noch das gleiche gemischte Bild und Text wie zuvor, haha, für PC, vielleicht kannst du den variablen Text rechts und direkt ignorieren Legen Sie die Breite fest, aber bewegen Sie sich. Tut mir leid, Duana, dieser variable Faktor muss berücksichtigt werden.

这个估计90%的移动端都有这个效果,当然不可能设计给你的是375px的稿子,然后你就做了个375px宽度的效果。但是如果按照设计稿的比例,然后设置图片和宽度的百分比呢,这种情况图片宽度的改变,当然会影响图片高度的改变(如果是固定的高度那图片估计就没法看了,各种被拉伸或是变形),而图片高度的改变就会影响整体行的改变,那估计拿着不同的手机,看到的右边的文字内容或高或低也是醉了。

百分比效果大概如下图:

Invariant und variabel im CSS-Design

所以这里一般设计的是图片固定大小不变,右边文字可变,占满其余空间。实现跟上面的图文混排一样,当然技术上可以使用很多方法如flex,absolute,float等

单行列表

同样单行列表,标题因为长度不一属于可变因子,不宜直接控制其宽度。而右侧的一些按钮或辅助信息相对来说使用绝对定位在右边比较合理。

ul.line-list
    li
        p.title+i.icon-xxx
.line-list li{
    position: relative;
    padding-right: 40px;
    line-height: 40px;
}
.line-list li .icon-xxx{
    position: absolute;
    right: 10px;
    top: 50%;
    tranform: translate(0, -50%);
}
// 如果文字比较长,需要做超出省略截断
.line-list li .title{
    padding-left: 10px;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

等分

这里的等分指水平的等分,可以使用的技术有flex,float,table-cell等,其中float应该是最low的,因为你必须要设置item的宽度,三等分设置33.33%,四等分设置25%等,这种重复利用性太low,已经不适合更高级的移动端了,所以flex和table-cell是不错的选择,根本不需要在意item的个数(当然得确定一行能显示下,显示不下那也是悲催)。所以这种情况下连单位都是多余的。

ul.equal-list
    li*n
// flex
.equal-list{
    display: flex;
}
.equal-list li{
    flex: 1;
}
// table-cell
.equal-list{
    display: table;
    table-layout: fixed;
    width: 100%;
}
.equal-list li{
    display: table-cell;
}

translate

translate中使用的百分比单位是针对自己宽高的百分比,所以对于未知宽高的计算来说,是非常大的优势,尤其用在水平和垂直居中上。

.center-translate{ position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
}

当然这些变与可变的还有很多,总之,在移动端的可变因子比pc上更多,更多的对宽度或高度的不确定,就需要各种方法去避免直接设置死宽度或高度,当然庆幸的是,css3的支持让这些不确定因素的控制变得趋向简单。

变与不变之道

最后不管是移动端还是pc端,对于动不动就设置一个具体width或height的方式注定可扩展性欠缺。所以尤其是在做通用组件的时候,一定要进一步深挖掘,了解更多的使用场景,每个场景的一些特殊特征,甚至于对未来的修改都有可预见性。

可能这里说得更多的是宽度方面的控制,其实对于方法的选择也一样,同一种效果,可能有很多方法去实现,而每种方法都有各自的利弊,所以也要根据实际情况去灵活变通使用,这同样也属于可变的。如果你所有的都是一刀切,那就是固定的一个思维了,无所谓变通了。

如果从一个更高的角度来说,没有什么是恒定的不变,一切皆可变。也许这个站点的不可变,到了那个站点就得变,所以拒绝教条主义,一切从实际情况出发,根据需求分析,得出一个合理的实践。


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
CSS -Einbeziehung: Auswählen der richtigen Methode für Ihr ProjektCSS -Einbeziehung: Auswählen der richtigen Methode für Ihr ProjektMay 16, 2025 am 12:02 AM

TheBestMethodforincludingCSSDependsonProjectSizeandComplexität: 1) ForlargerProjects, UsexternalcssforbetterTainability undPerformance.2) ForsMallerProjects, InternalcsSSuStoVoidextrahttprequests.AldalwaysConsidaNanceSrahtTprequest.

Dies soll nicht passieren: Fehlerbehebung beim UnmöglichenDies soll nicht passieren: Fehlerbehebung beim UnmöglichenMay 15, 2025 am 10:32 AM

Wie es aussieht, eines dieser unmöglichen Probleme zu beheben, die sich als etwas ganz anderes herausstellen, an das Sie nie gedacht haben.

@Keyframes vs CSS Übergänge: Was ist der Unterschied?@Keyframes vs CSS Übergänge: Was ist der Unterschied?May 14, 2025 am 12:01 AM

@KeyFramesandcsStransitionSdifferinComplexity:@keyFramesAllowsfordetailedanimationsequenzen, whilecsStransitionShandleSmplestatechanges.USecsStransitionsForHovereffectSlikeButtonColorchanges sowie@keyframesforintricateanimationslikerotierungen.

Verwenden von Seiten CMS für statische Site Content ManagementVerwenden von Seiten CMS für statische Site Content ManagementMay 13, 2025 am 09:24 AM

Ich weiß, ich weiß: Es gibt eine Menge von Content -Management -Systemoptionen, und während ich mehrere getestet habe, war keiner wirklich derjenige, den Sie wirklich wissen? Seltsame Preismodelle, schwierige Anpassungen, einige werden sogar ein Ganzes &

Die ultimative Anleitung zum Verknüpfen von CSS -Dateien in HTMLDie ultimative Anleitung zum Verknüpfen von CSS -Dateien in HTMLMay 13, 2025 am 12:02 AM

Das Verknüpfen von CSS -Dateien mit HTML kann durch die Verwendung von Elementen in einem HTML erreicht werden. 1) Verwenden Sie Tags, um lokale CSS -Dateien zu verknüpfen. 2) Mehrere CSS -Dateien können durch Hinzufügen mehrerer Tags implementiert werden. 3) Externe CSS -Dateien verwenden absolute URL -Links wie z. 4) Stellen Sie die korrekte Verwendung von Dateipfaden und CSS -Dateiladeauftrag sicher und optimieren Sie die Leistung können mit CSS -Präprozessor zusammengeführt werden, um Dateien zu verschmelzen.

CSS Flexbox vs Grid: Eine umfassende ÜberprüfungCSS Flexbox vs Grid: Eine umfassende ÜberprüfungMay 12, 2025 am 12:01 AM

Die Auswahl von Flexbox oder Grid hängt von den Layoutanforderungen ab: 1) Flexbox ist für eindimensionale Layouts wie die Navigationsleiste geeignet. 2) Das Gitter eignet sich für zweidimensionale Layouts wie Zeitschriftenlayouts. Die beiden können im Projekt verwendet werden, um den Layout -Effekt zu verbessern.

So füge CSS -Dateien ein: Methoden und Best PracticesSo füge CSS -Dateien ein: Methoden und Best PracticesMay 11, 2025 am 12:02 AM

Der beste Weg, um CSS -Dateien einzubeziehen, besteht darin, Tags zu verwenden, um externe CSS -Dateien in den HTML -Teil einzuführen. 1. Verwenden Sie Tags, um externe CSS -Dateien einzuführen, wie z. 2. Für kleine Anpassungen können Inline -CSS verwendet werden, sollten jedoch mit Vorsicht verwendet werden. 3. Große Projekte können CSS -Präprozessoren wie SASS oder weniger verwenden, um andere CSS -Dateien über @import zu importieren. 4. Für die Leistung sollten CSS -Dateien zusammengeführt und CDN verwendet und mit Tools wie CSSNano komprimiert werden.

Flexbox vs Grid: Soll ich sie beide lernen?Flexbox vs Grid: Soll ich sie beide lernen?May 10, 2025 am 12:01 AM

Ja, youShouldlearnbothflexBoxandgrid.1) FlexBoxiSidealfore-dimensional, flexibelayoutslikenAvigationMenus.2) GridexcelStwo-dimensional, komplexDesignsuchasmagazinelayouts.3) Kombininierungs-Botenhances-Flexible-und-und -Anteilungskraft, und -forsfossivität,

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Nordhold: Fusionssystem, erklärt
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software