Materiālās ēnas CSS-triki

Anonim

Materiālu dizains pēdējā laikā ir bijis visur. Viena tā daļa sastāv no slāņu sakraušanas virs otra kā īstas papīra loksnes. Lai panāktu šādu efektu CSS, mums ir jāizmanto box-shadowīpašums.

Lai izvairītos no ēnu manuālas rakstīšanas katru reizi, mēs tam varam izveidot nelielu Sass mixin. Vienīgais, ko šis miksins darīs, ir box-shadowdeklarācijas izveide, pamatojoties uz norādīto $depth(no 0 līdz 5). Ēnas faktiski tiks aprēķinātas ar divām funkcijām: bottom-shadowun top-shadow.

/// Gives a card depth effect. /// @param (Number) $depth - depth level (between 1 and 5) /// @link http://www.google.com/design/spec/layout/layout-principles.html#layout-principles-dimensionality Google Design /// @requires (function) top-shadow /// @requires (function) bottom-shadow @mixin card($depth) ( @if $depth 5 ( @warn "Invalid $depth `#($depth)` for mixin `card`."; ) @else ( box-shadow: bottom-shadow($depth), top-shadow($depth); ) )

Neaizmirsīsim mūsu divas funkcijas:

/// Computes a top-shadow for a card effect. /// @param (Number) $depth - depth level /// @return (List) @function top-shadow($depth) ( $primary-offset: nth(1.5 3 10 14 19, $depth) * 1px; $blur: nth(1.5 3 10 14 19, $depth) * 4px; $color: rgba(black, nth(.12 .16 .19 .25 .30, $depth)); @return 0 $primary-offset $blur $color; ) /// Computes a bottom-shadow for a card effect. /// @param (Number) $depth - depth level /// @return (List) @function bottom-shadow($depth) ( $primary-offset: nth(1.5 3 6 10 15, $depth) * 1px; $blur: nth(1 3 3 5 6, $depth) * 4px; $color: rgba(black, nth(.24 .23 .23 .22 .22, $depth)); @return 0 $primary-offset $blur $color; )

Skatiet Hugo Giraudel (@HugoGiraudel) pildspalvas materiālu ēnu vietnē CodePen.