nl.hideout-lastation.com
Paradijs Voor Ontwerpers En Ontwikkelaars


Items verplaatsen in CSS-rasterlay-out [Gids]

Het gebruik van de CSS Grid Layout Module in webdesign wordt steeds meer haalbaar naarmate meer browsers het gaan ondersteunen . Bij het maken van lay-outs voor het invullen van rastercellen, kan er echter een moment komen waarop u ingewikkeldere dingen wilt bereiken.

U kunt bijvoorbeeld een beetje van de rasteritems die in de rastergedeelten vastzitten enigszins verplaatsen . Je kunt ze ook uit de rastercontainer (overloop) of over elkaar (overlapping) of alleen ... naar een lege ruimte in de buurt verplaatsen.

In dit bericht laat ik u zien hoe u rasteritems kunt verplaatsen, rangschikken, overlopen, overlappen en van grootte kunt voorzien wanneer u de CSS Grid-lay-outmodule gebruikt.

Maak een CSS-raster

Laten we eerst een eenvoudig CSS-raster maken met één rij en drie kolommen .

In de HTML maken we een aantal divs waarbij de rastercontainer de drie rasteritems bevat .

In de CSS heeft de rastercontainer het display: grid; eigenschap en de rasteritems hebben een grid-area dat de namen van de rasteritems aanduidt.

We voegen ook de eigenschap grid-template-areas aan de rastercontainer, waarin de rasternamen worden gebruikt om de rastergebieden toe te wijzen aan de rastercellen die ze vertegenwoordigen .

Alle kolommen hebben de grootte van één breuk ( fr ) van de breedte van de container, waardoor de insluiting van de rasteritems wordt gegarandeerd.

 .grid-container {weergave: raster; grid-sjabloon-gebieden: 'left center right'; rooster-sjabloon-kolommen: herhaling (3, 1fr); rooster-sjabloon-rijen: 80px; grid-gap: 5px; breedte: 360 px; achtergrondkleur: magenta; }. grid-left {grid-area: left; }. grid-center {grid-area: center; } .grid-right {grid-area: right; } .grid-container div {background-color: lightgreen; } 

Overloop raster items

U kunt een rasteritem de rastercontainer laten overlopen als dit voor een opmaak nodig is. Om het overflow-effect te bereiken, hoeft u alleen een andere kolomgrootte te gebruiken :

 .grid-container {weergave: raster; grid-sjabloon-gebieden: 'left center right'; rooster-sjabloon-kolommen: herhaal (3, 150 px); grid-gap: 5px; } 

De som van de kolom- en gap-afmetingen is groter dan de breedte van de container, waardoor de rasteritems hun container overlopen.

Overlap roosteritems

Een rasteritem kan in de volgende gevallen elkaar overlappen (geheel of gedeeltelijk dekken) een ander rasteritem :

  1. Het is ingesteld om de cel (len) van een ander rasteronderdeel over (en over) te leggen.
  2. De grootte is verhoogd, waardoor deze overlapt met het nabije rasteritem.
  3. Het wordt verplaatst bovenop een ander rasteritem.

We bespreken de tweede en derde gevallen later in de secties 'Dimensioneren' en 'Verplaatsen'.

Laten we eerst het eerste geval bekijken wanneer een roosteritem over een ander item loopt .

Het rasteritem in het midden heeft over de linkerbalk gespannen, dus slechts twee items zijn zichtbaar op het scherm.

 . grid-center {grid-area: center; rasterkolom: 1/3; } 

Aan de eigenschappen van de rasterkolom en de rastijl worden rasterlijnen toegekend waartussen een kolom of rij moet passen.

In het onderstaande diagram ziet u hoe de grid-column: 1 / 3 1/3 CSS-regel werkt: de middelste kolom loopt tussen de rasterlijnen 1 en 3 . Als gevolg overlapt de middelste kolom de linker kolom.

Rasteritems verplaatsen

Door te bewegen, bedoel ik de items een beetje verplaatsen . Als u een item volledig in een andere rastercel / gebied wilt verplaatsen, raad ik u aan de code voor het maken van het raster bij te werken.

Het verplaatsen van rasteritems is eenvoudig. Gebruik gewoon de margin, de transform of de position:relative; eigenschappen . Zie hieronder hoe de items worden verplaatst met behulp van die eigenschappen.

De middelste en rechter rasteritems kunnen op de volgende manieren worden verplaatst (zoals hierboven weergegeven):

1. Gebruik margin

Negatieve marges vergroten de afmetingen van rasteritems, terwijl positieve marges deze inkorten. Door een combinatie van beide te gebruiken, kunt u de rasteritems enigszins verplaatsen.

 . grid-center {grid-area: center; margin-left: -10px; margin-right: 10px; margin-top: -10px; margin-bottom: 10px; } .grid-right {grid-area: right; marge links: 10 px; margin-right: -10px; margin-top: -10px; margin-bottom: 10px; } 
2. transform

De functie translate() CSS verplaatst een element langs de x- en y-assen . Door het samen met de eigenschap transform, kunt u de positie van een rasteritem wijzigen.

 . grid-center {grid-area: center; transform: translate (-10px, -10px); } .grid-right {grid-area: right; transform: translate (10px, -10px); } 
3. position

Gebruik van de position: relative; regel met de opgegeven eigenschappen top, bottom, left en right kan ook worden gebruikt voor het verplaatsen van rasteritems.

 . grid-center {grid-area: center; positie: relatief; onderkant: 10px; rechts: 10px; } .grid-right {grid-area: right; positie: relatief; onderkant: 10px; links: 10px; } 

Rasteritems bestellen

Rasteritems worden op het scherm weergegeven in de volgorde waarin ze in de HTML-broncode voorkomen .

In het vorige gedeelte, toen het middelste item naar links werd verplaatst, werd het door de browser bovenop het linkse item geplaatst. Dit gebeurde omdat in de HTML,

komt na
, dus het middelste item wordt weergegeven na (en over) de linker.

We kunnen de volgorde van roosteritems echter wijzigen met behulp van de z-index of de CSS-eigenschappen van de order .

De z-index: 1; regel, het linker roosteritem kreeg een hogere stapelcontext .

 . grid-left {grid-area: left; z-index: 1; } 

Net als in de CSS Grid Layout-module heeft het wijzigen van de elementvolgorde in HTML geen invloed op de rasterlay-out, u kunt deze ook plaatsen

voor
in de HTML. Doe dit echter alleen als de bijgewerkte HTML-code de toegankelijkheid niet schaadt.

Size grid items

Als u rijen of kolommen van een automatisch formaat gebruikt voor een rasteritem (met behulp van de eenheden auto, fr, gr ), krimpt dit om ruimte te maken voor het naburige artikel dat alleen in grootte is gegroeid als het artikel niet is aangepast door een transform of een negatief marge .

Vergeet niet dat in ons voorbeeldraster alle drie de kolommen één breuk ( fr ) van de rastercontainer innemen. Bekijk hoe alle drie de items eruitzien nadat de linkerzijde op twee verschillende manieren is verkleind.

1. Gemeten met width en height

Hier veranderen we de grootte van het linker item met behulp van de eigenschappen width en height . Als gevolg hiervan blijft het in de roostercontainer.

.grid-left {grid-area: left; breedte: 200 px; hoogte: 90 px; }
2. Sized met transform

Hier veranderen we de grootte van het linker item met behulp van de eigenschap transform . Als gevolg hiervan loopt de container over en verdwijnt ook de roosteropening.

.grid-left {grid-area: left; transform: scalex (1.8); }

Ontwerpers: waar ter wereld moet je werken

Ontwerpers: waar ter wereld moet je werken

Er is een romantische mythologie rond bepaalde steden . In feite is alles wat je hoeft te doen ze te noemen, en duizend afbeeldingen worden opgeroepen in je brein, het product van tientallen jaren geschiedenis en populaire cultuurreferenties. Parijs. Milaan. Londen. Rio de Janeiro. New York . Waar je ook woont, je hebt waarschijnlijk al van deze plaatsen gehoord en je weet precies waar ze beroemd om zijn

(Technische en ontwerptips)

Een kijkje in: Firefox Developer Edition

Een kijkje in: Firefox Developer Edition

Na een korte plaag heeft Mozilla officieel Firefox Developer Edition uitgebracht. Het is een nieuwe browser die specifiek is bedoeld voor webontwikkelaars . Hoewel het officieel niet is aangekondigd, lijkt het erop dat het op enig moment Firefox Aurora gaat vervangen.Afgaande op de naam, de officiële aankondigingen en de landingspagina lijkt het erop dat Firefox Developer Edition de eerste grote browser is die is ontwikkeld voor ontwikkeling en niet alleen ter ondersteuning.

(Technische en ontwerptips)