
We bring to your attention a collection of useful CSS snippets in which you can figure out in 30 seconds, or even faster.
Allows an item to automatically apply clear to its children.
Note: only useful if you still use float when creating layouts. Consider switching to more modern approaches using flexbox or mesh.
<div class="clearfix"> <div class="floated">float a</div> <div class="floated">float b</div> <div class="floated">float c</div> </div> .clearfix::after { content: ""; display: block; clear: both; } .floated { float: left; } 
.clearfix::after defines a pseudo-element.content: '' allows the pseudo-element to affect the layout.clear: both means that within one block formatted context, the left or right, or both sides of the element cannot adjoin the elements to which the float was previously applied.99+%
There are no underwater stones.
If the element has a width change, then the height dynamically changes proportionally, with a given coefficient (that is, the ratio of width to height remains unchanged).
<div class="constant-width-to-height-ratio"></div> .constant-width-to-height-ratio { background: #333; width: 50%; padding-top: 50%; } padding-top and padding-bottom can be used as an alternative to height , since the percentage of the height of the element becomes the percentage of the width. That is, 50% means that the element height will be 50% of the width. As a result, the aspect ratio does not change.
99+%
padding-top shifts all content to the bottom of the element.
Changes the text selection style.
<p class="custom-text-selection">Select some of this text.</p> .custom-text-selection::selection { background: red; color: white; } 
::selection defines a pseudo-selector in the element to apply a style to the text when it is selected.
84.6%
This feature is not yet in the specifications, for its full support you need to use prefixes.
Variables that can be reused for the transition-timing-function properties provide more options than the built-in ease , ease-in , ease-out and ease-in-out .
<div class="easing-variables"></div> :root { --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53); --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19); --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22); --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06); --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035); --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335); --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94); --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1); --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1); --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1); --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1); --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1); --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955); --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1); --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1); --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1); --ease-in-out-expo: cubic-bezier(1, 0, 0, 1); --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86); } .easing-variables { width: 50px; height: 50px; background: #333; transition: transform 1s var(--ease-out-quart); } .easing-variables:hover { transform: rotate(45deg); } 
Variables declared globally outside the pseudo-class: root CSS, which match the root element of the document tree. In HTML: root corresponds to the element and is identical to the html selector, except that its specificity is higher.
87.2%
There are no underwater stones.
Creates a depressed or engraved text background.
<p class="etched-text">I appear etched into the background.</p> .etched-text { text-shadow: 0 2px white; font-size: 1.5rem; font-weight: bold; color: #b8bec5; } 
text-shadow: 0 2px white creates a white shadow with an offset of 0px horizontally and 2px vertically from its original position. The background should be darker than the shade, and the text should be slightly faded so that it looks impressed / engraved against the background.
97.9%
There are no underwater stones.
Makes a gradient fill text.
<p class="gradient-text">Gradient text</p> .gradient-text { background: -webkit-linear-gradient(pink, red); -webkit-text-fill-color: transparent; -webkit-background-clip: text; } 
background: -webkit-linear-gradient(...) makes a gradient background on a text element.webkit-text-fill-color: transparent fills the text with a transparent color.webkit-background-clip: text reinforces the background with text, fills the text with a gradient background as a color.90.7%
️ Uses non-standard properties.
It makes a border around the element, the thickness equivalent to one native pixel of the device, very sharp, not blurred.
<div class="hairline-border">text</div> .hairline-border { box-shadow: 0 0 0 1px; } @media (min-resolution: 2dppx) { .hairline-border { box-shadow: 0 0 0 0.5px; } } @media (min-resolution: 3dppx) { .hairline-border { box-shadow: 0 0 0 0.33333333px; } } @media (min-resolution: 4dppx) { .hairline-border { box-shadow: 0 0 0 0.25px; } } 
Box-shadow when using a spread ( spread ) adds a pseudo frame, which can use subpixels *.@media (min-resolution: ...) to check the ratio of logical and physical pixels on the device (device pixel ratio) ( 1ddpx equivalent to 96 DPI), set the box-shadow spread to 1 / dppx .95%
️For full support, an alternate syntax and validation of a JavaScript user agent is needed.
https://caniuse.com/#feat=css-media-resolution
border . Safari does not support them for box-shadow . Firefox supports subpixel values in both cases.Centers the child element vertically and horizontally within the parent element.
<div class="horizontal-and-vertical-centering"> <div class="child"></div> </div> .horizontal-and-vertical-centering { display: flex; justify-content: center; align-items: center; } 
display: flex includes flexbox.justify-content: center centers the child horizontally.align-items: center centers the child vertically.97.8%
️For full support, prefixes are needed.
When you hover the cursor is accompanied by a gradient effect.
<button class="mouse-cursor-gradient-tracking"> <span>Hover me</span> </button> .mouse-cursor-gradient-tracking { position: relative; background: #2379f7; padding: 0.5rem 1rem; font-size: 1.2rem; border: none; color: white; cursor: pointer; outline: none; overflow: hidden; } .mouse-cursor-gradient-tracking span { position: relative; } .mouse-cursor-gradient-tracking::before { --size: 0; content: ''; position: absolute; left: var(--x); top: var(--y); width: var(--size); height: var(--size); background: radial-gradient(circle closest-side, pink, transparent); transform: translate(-50%, -50%); transition: width .2s ease, height .2s ease; } .mouse-cursor-gradient-tracking:hover::before { --size: 200px; } JavaScript var btn = document.querySelector('.mouse-cursor-gradient-tracking') btn.onmousemove = function (e) { var x = e.pageX - btn.offsetLeft var y = e.pageY - btn.offsetTop btn.style.setProperty('--x', x + 'px') btn.style.setProperty('--y', y + 'px') } 
::before defines a pseudo-element--size , --x , --y are a set of custom CSS propertiesbackground: radial-gradient(circle closest-side, pink, transparent); defines gradient--size: 200px; show gradient on hoverbtn.style.setProperty('--x', x + 'px') and btn.style.setProperty('--y', y + 'px') determine the position of the block with the gradient relative to the containerNote. If the parent element is positioned relative to the content ( position: relative ), then it will also have to subtract and its offset.
var x = e.pageX - btn.offsetLeft - btn.offsetParent.offsetLeft var y = e.pageY - btn.offsetTop - btn.offsetParent.offsetTop 87.2%
JavaScript JavaScript required.
Adds a gradient to the redundant element to better display the content that can be scrolled.
<div class="overflow-scroll-gradient"> <div class="overflow-scroll-gradient__scroller"> Content to be scrolled </div> </div> CSS .overflow-scroll-gradient { position: relative; } .overflow-scroll-gradient::after { content: ''; position: absolute; bottom: 0; width: 300px; height: 25px; background: linear-gradient(rgba(255, 255, 255, 0.001), white); /* transparent keyword is broken in Safari */ } .overflow-scroll-gradient__scroller { overflow-y: scroll; background: white; width: 300px; height: 250px; padding: 15px 0; line-height: 1.2; text-align: center; } 
position: relative to the parent element specifies the Cartesian positioning of the pseudo-elements.::after defines a pseudo-element.background-image: linear-gradient(...) adds a linear gradient from transparent to white (top to bottom).position: absolute takes a pseudo-element from the document stream and positions it relative to the parent element.width: 300px specifies the size of the scrollable element (child relative to the parent containing the pseudo-element).height: 25px is the height of the gradient pseudo-element, it should be relatively small.bottom: 0 positions the pseudo-element at the bottom of the parent element.94.8%
There are no underwater stones.
When you hover the cursor, the interactive menu pops up.
<div class="reference"> <div class="popout-menu"> Popout menu </div> </div> .reference { position: relative; } .popout-menu { position: absolute; visibility: hidden; left: 100%; } .reference:hover > .popout-menu { visibility: visible; } 
position: relative for the reference parent element sets the Cartesian positioning of the child element.position: absolute takes a pop-up menu from the document flow and positions it relative to the parent element.left: 100% entire menu to the left of the parent element.visibility: hidden initially hides the menu and allows transitions (unlike display: none)..reference:hover > .popout-menu means that when the mouse cursor passes over .reference, the child elements with the class .popout-menu are selected immediately, and their visibility changes to visible, as a result we see the menu.99+%
There are no underwater stones.
A prettier alternative to text-decoration: underline , when the line does not intersect the lower bearing elements of the letters. Natively implemented as text-decoration-skip-ink: auto , but at the same time we have less opportunity to control the underlining.
<p class="pretty-text-underline">Pretty text underline without clipping descending letters.</p> .pretty-text-underline { display: inline; font-size: 1.25rem; text-shadow: 1px 1px 0 #f5f6f9, -1px 1px 0 #f5f6f9, -1px -1px 0 #f5f6f9, 1px -1px 0 #f5f6f9; background-image: linear-gradient(90deg, currentColor 100%, transparent 100%); background-position: 0 1.04em; background-repeat: repeat-x; background-size: 1px 1px; } .pretty-text-underline::selection { background-color: rgba(0, 150, 255, 0.3); text-shadow: none; } 
text-shadow: ... has four values with shifts, covering the area of 4 × 4 pixels, so that the underscore has a “thick” shadow covering the line at the intersection of the letter letter. Use the background color. For larger fonts, set a larger areabackground-image: linear-gradient(...) creates a 90-degree gradient of the current text color (currentColor).background-* properties specify a 1 × 1 px gradient at the bottom and repeat it along the X axis.::selection is responsible for ensuring that the text's shadow does not overlap the text selection.94.8%
Firefox requires prefixes to work in ::selection
Uses the SVG form to separate two different blocks to get a visually more interesting display on the screen compared to the standard horizontal split.
<div class="shape-separator"></div> .shape-separator { position: relative; height: 48px; } .shape-separator::after { content: ''; background-image: url(); position: absolute; width: 100%; height: 24px; bottom: 0; } image / svg + xml; base64, PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiIHN0cm9rZS1taXRlcmxpbWl0PSIxLjQxNCI + PHBhdGggZD0iTTEyIDEybDEyIDEySDBsMTItMTJ6IiBmaWxsPSIjZmZmIi8 + PC9zdmc +); .shape-separator { position: relative; height: 48px; } .shape-separator::after { content: ''; background-image: url(); position: absolute; width: 100%; height: 24px; bottom: 0; } 
position: relative gives the element a Cartesian positioning of the pseudo-elements.::after specifies the pseudo-element.background-image: url(...) adds a SVG form (triangle 24 × 24 in base64 format) as a background image of a pseudo-element, which is repeated many times by default. It must be the same color as the detachable block.position: absolute takes a pseudo-element from the document stream and positions it relative to the parent element.width: 100% stretches an element across the entire width of its parent element.height: 24px sets the same height as the SVG form.bottom: 0 positions the pseudo-element at the bottom of the parent element.98%
There are no underwater stones.
Uses native operating system fonts to make the application look as natural as possible.
<p class="system-font-stack">This text uses the system font.</p> .system-font-stack { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", Helvetica, Arial, sans-serif; } 
The browser searches for each of the fonts listed below. If the first font is unavailable - it searches for the second, if it is also unavailable - it searches for the third, etc.
-apple-system is the San Francisco font used in iOS and macOS (but not in Chrome).BlinkMacSystemFont is the San Francisco font used in macOS Chrome.Segoe UI used in Windows 10.Roboto - in Android.Oxygen-Sans - in GNU + Linux.Ubuntu is in Linux."Helvetica Neue" and Helvetica - in macOS 10.10 and below (taken in quotes, because there is a space in the name).Arial widely supported by all OS.sans-serif - spare sans serif font, used if all of the above are not available.99+%
There are no underwater stones.
With pure CSS, it creates a triangular shape.
<div class="triangle"></div> .triangle { width: 0; height: 0; border-top: 20px solid #333; border-left: 20px solid transparent; border-right: 20px solid transparent; } 
The border color is the color of the triangle itself. The side toward which the vertex of the triangle faces is opposite to the border-* property. For example, border-top means that the arrow points down.
Experiment with px values to change the proportions of the triangle.
99+%
There are no underwater stones.
If the text is longer than one line, it will be cut off, and an ellipsis will be substituted at the end.
<p class="truncate-text">If I exceed one line's width, I will be truncated.</p> .truncate-text { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; } 
overflow: hidden does not allow the text to go beyond the limits of the dimensions (for a block it is 100% of the width and automatic height).white-space: nowrap does not allow text to take one line in height.text-overflow: ellipsis makes it so that when the text reaches the specified size, an ellipsis is inserted at the end.98.1%
Only works with single line items.
Source: https://habr.com/ru/post/350160/
All Articles