css-tips-tricks
css-tips-tricks copied to clipboard
Handmade collection of css tips tricks. Give it a star if you find it useful 🌟
CSS Tips Tricks
A handmade collection of pro css tips tricks 🌟
- Contributing
- Support
- License
Useful Resources
Make sure to subscribe to our youtube channel channel and also don't forget to star 🌟 the open-source portfolio-template I created for anyone to use for free.
Table of Contents
- Create Documentation Styled Layout
- Make Webpages Scroll Smoothly
- Adding Stroke to Text
- Check If Selector Is Supported
- Check If Property Is Supported
- Play and Pause Animations
- Improve Media Defaults
- Make text readable on images
- Style Optional Form Elements
- The Custom Cursors
- Move Table Caption to the bottom
- Create Text Columns
- Styling video states via :paused and :playing pseudo classes
- Change Writing Mode
- Providing Fallback Values for Variables
- Zooming Images on Hover
- Emphasizing Text Content
- Create Gradient Shadows
- Five Ways of Centering Divs
- Fill Text With Images
- Style Drop Caps
- Add Leading Zeros to Ordered Lists
- Using Emoji as List Style Type
- Adding Indentation to Text
- Add Dark Mode Support on Your Website
- Disable Textarea Resizing
- Rainbow Animation
- Use clamp() for Responsive Typography
- Create A Sticky Footer
Create Documentation Styled Layout
You can craft a responsive documentation-styled layout using CSS grid with only two lines of CSS.
<div class="parent">
<aside>Sidebar</aside>
<main>Documentation</main>
</div>
.parent{
display: grid;
grid-template-columns: minmax(150px, 25%) 1fr;
}
See result
data:image/s3,"s3://crabby-images/4d23f/4d23f824519518508fb5d4bc63dd34866848105e" alt="documentation styled layout"
back to table of contents
Smooth Scrolling
For implementing smooth scrolling for a page add scroll-behavior: smooth
to the html element.
html {
scroll-behavior: smooth;
}
See result
data:image/s3,"s3://crabby-images/cac98/cac984460a3d4a235fdc06d2841610832cabcc2b" alt="smooth scrolling to different sections"
back to table of contents
Adding Stroke to Text
Use text-stroke
property it adds a stroke or outline to the text elements.
/* Width and color values */
h1 {
-webkit-text-stroke: 5px crimson;
text-stroke: 5px crimson;
}
See result
data:image/s3,"s3://crabby-images/5c247/5c2475f53259fb69ada2733d33abce0df8d6c52a" alt="Netlify"
back to table of contents
Check If Selector Is Supported
You can check if a selector is supported by your browser or not using the selector()
within the @supports
rule.
@supports (selector(div:has(pre))) {
/* Code that will only run if the selector is supported */
p {
color: crimson;
}
}
back to table of contents
Check If Property Is Supported
You can also detect properties support using the CSS @supports
rule.
@supports (display: grid) {
main {
display: grid;
}
}
Chris Coyier has done an exceptional job of providing valuable insights and information on the @supports
rule, Also Known as Feature queries. Read here.
back to table of contents
Play and Pause Animations
Use the animation-play-state
property to play and pause an animation.
For example: Playing an animation on hover.
/* By default animation is paused */
.box {
animation-name: rotate;
animation-duration: 0.7s;
animation-iteration-count: infinite;
animation-play-state: paused;
}
/* Play animation on hover */
.box:hover {
animation-play-state: running;
}
@keyframes rotate {
0% {
transform: rotate(0);
}
100% {
transform: rotate(360deg);
}
}
See result
data:image/s3,"s3://crabby-images/33ca2/33ca2ad97c648e0f0dd235bea09316c7b0091fa7" alt="custom cursor"
back to table of contents
Improve Media Defaults
Images are inline elements, and by setting the default value to display:block;
we can avoid many potential issues. Setting max-width:100%;
we prevent images from overflowing when they are in a container that is not wide enough to contain them.
img, picture, video, svg {
display: block;
max-width: 100%;
object-fit: contain;
}
Additionally, I have set object-fit:contain;
to ensure that images preserve a nice aspect ratio.
back to table of contents
Make text readable on images
Add linear-gradient overlay on your images to make your text content readable and accessible for users.
.header {
background-image: linear-gradient(#ffffffa2, #ffffffe6),url("images/hero-bg.jpg");
}
See result
Not using gradient
data:image/s3,"s3://crabby-images/68b5c/68b5caa6f2d132b1994a81cc009fd944fef57a49" alt="custom cursor"
Uses gradient
data:image/s3,"s3://crabby-images/f6cbc/f6cbc644d53b4e93ce12f09d5200608102f20be7" alt="custom cursor"
back to table of contents
Style :optional
Form Elements
You can style form fields like input
, select
, and textarea
that do not have a required attribute on them using the :optional
pseudo-class.
/* Selects all optional form fields */
*:optional{
background-color: green;
}
Note: Use :required
pseudo-class to select required form fields.
back to table of contents
The Custom Cursor
You can customize your cursor
from an arrow pointer to a custom image.
html{
cursor: url('images/no.jpg'), auto;
}
Note: auto
will be used as fallback value in case image does not load for some reason.
See result
data:image/s3,"s3://crabby-images/4f906/4f906bd973fdec7fedb1855841e8db7b56fcbf36" alt="custom cursor"
back to table of contents
Move Table Caption to Bottom
Use the caption-side
property to place the table caption or table title on a specified side of the table.
table{
caption-side: bottom;
}
See result
data:image/s3,"s3://crabby-images/c57b8/c57b851f03cb1d9c0e57745a5a46dd09a1ed35f7" alt="changing table caption side from top to bottom"
back to table of contents
Styling video states via :paused
and :playing
pseudo classes
Use :paused
selector to style media elements like audio, and video when in paused state likewise paused we also have :palying
pseudo-class selector.
video:paused {
opacity: 0.6;
}
Note: At the moment, this feature is only supported in Safari, but you can use this helpful tool to check for the latest support across different browsers.
See result
data:image/s3,"s3://crabby-images/20c51/20c51fd557780cb2c73efe9064a43855bd478011" alt="plam tree gif on a beach"
back to table of contents
Create Text Columns
Craft nice column layouts for text elements using column properties.
p{
column-count: 3;
column-gap: 4.45rem;
column-rule: 2px dotted crimson;
}
See result
data:image/s3,"s3://crabby-images/cb1e7/cb1e72569a1ce6e511a390b3a1cb1e0fa9d67640" alt="3 text columns"
back to table of contents
Change Writing Mode
You can use the writing-mode
property to specify how text should be laid out on your website.
/* Specifies the text layout direction to sideways-lr */
h1 {
writing-mode: sideways-lr;
}
/* Keyword values (Reference: MDN) */
writing-mode: horizontal-tb;
writing-mode: vertical-rl;
writing-mode: vertical-lr;
See result
data:image/s3,"s3://crabby-images/e0f4e/e0f4e2dbfd5e2e3acea4e9419b7cbb8503687251" alt="text starting from sideways-lr"
back to table of contents
Providing Fallback Values for Variables
Specify fallback values for custom properties. In case a variable is not defined or found for some reason the fallback value will be used.
/* Purple color will be applied as var(--black) is not defined */
:root {
--orange: orange;
--coral: coral;
}
h1 {
color: var(--black, purple);
}
back to table of contents
Zooming Images on Hover
You can create a zoom-in effect when hovering over an image, this is a technique commonly used on e-commerce websites.
/* Define the height and width of the image container & hide overflow */
.img-container {
height: 250px; width: 250px; overflow: hidden;
}
/* Make the image inside the container fill the container */
.img-container img {
height: 100%;
width: 100%;
object-fit: cover;
transition: transform 200ms ease-in;
}
img:hover{
transform: scale(1.2);
}
See result
data:image/s3,"s3://crabby-images/0b73a/0b73a9ae263a807590874c6cb841a30e7ddfb5ca" alt="shoping bag on grey tiles"
back to table of contents
Emphasizing Text Content
Use text-emphasis
property to apply emphasis marks to text elements.You can specify any string including emojis as its value.
h1 {
text-emphasis: "⏰";
}
Note: Please refer to MDN docs to learn more about this property.
See result
data:image/s3,"s3://crabby-images/e8cb4/e8cb4e663a84e70664e483c26aea9cdb6ba4644f" alt="Time is a healer"
back to table of contents
Create Gradient Shadows
This is how you can create gradient shadows for an exclusive user experience.
:root{
--gradient: linear-gradient(to bottom right, crimson, coral);
}
div {
height: 200px;
width: 200px;
background-image: var(--gradient);
border-radius: 1rem;
position: relative;
}
div::after {
content: "";
position: absolute;
inset: 0;
background-image: var(--gradient);
border-radius: inherit;
filter: blur(25px) brightness(1.5);
transform: translateY(15%) scale(0.95);
z-index: -1;
}
See result
data:image/s3,"s3://crabby-images/18066/1806613199e37024b1da7db21d4a2a596190f554" alt="box with gradient shadow"
back to table of contents
Five Ways of Centering Divs
Center a div
both vertically and horizontally.
/* 1.Centering with grid */
.parent{
height: 100vh;
display: grid;
place-items: center;
}
/* 2.Centering with grid & margins */
.parent{
display: grid;
}
.child{
margin: auto;
}
/* 3.Centering with positioning */
div{
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%,-50%);
}
/* 4.Centering with flexbox */
.parent{
height: 100vh;
display: flex;
justify-content: center;
align-items: center;
}
/* 5.Centering with flexbox & margins */
.parent{
display: flex;
}
.child{
margin: auto;
}
Note: When using layout tools like grid
, flexbox
or positioning elements are centered relative to the height of the parent element which is 100vh
here in our case, Also check out this great article by @bramus on using new viewport units.
back to table of contents
Fill Text With Images
You can fill your text content with a beautiful image with a few lines of CSS.
h1{
background-image: url('images/flower.jpg');
background-clip: text;
color: transparent;
background-color: white;
}
Note: Always specify background-color
when using this technique as this will be used as a fallback value in case the image does not load for some reason.
See result
data:image/s3,"s3://crabby-images/04765/04765846ee40a445c1f2fff1dfbea9633188a89c" alt="text filled with flower image"
back to table of contents
Style Drop Caps
Avoid unnecessary spans and use pseudo elements instead to style your content likewise first-letter
pseudo-element we also have first-line
pseudo-element.
h1::first-letter{
font-size: 2rem;
color:#ff8A00;
}
See result
data:image/s3,"s3://crabby-images/7baf8/7baf8759ff05746a816b1ab2a01e890e9c2338c8" alt="first letter of text styled differently"
back to table of contents
Add Leading Zeros to Ordered Lists
Enhance visual consistency and readability by adding leading zeros to the numbers in your ordered list items.
li{
list-style-type:decimal-leading-zero;
}
See result
data:image/s3,"s3://crabby-images/f198c/f198c022e09d3ef8fbed127b814580eb32fbc138" alt="decimal leading zero before list numbers"
back to table of contents
Using Emoji as list-style-type
You can use emojis as list style types It's a fun way to add some personality to your lists.
li{
list-style-type: '🐶';
}
back to table of contents
Adding Indentation to Text
Use the text-indent
property to indent the first line of a text block. Negative values are also allowed.
p{
text-indent:2.6rem;
}
See result
data:image/s3,"s3://crabby-images/15c67/15c679a9f2cde65005fbd79eef208240f22d5d8a" alt="first line of text block indented to the right side"
back to table of contents
Add Dark Mode Support to Your Website
You can add dark mode support to your website using CSS variables and the prefers-color-scheme
media query.
:root {
--bg-color: white;
--text-color: black;
}
body {
background-color: var(--bg-color);
color: var(--text-color);
}
@media (prefers-color-scheme: dark) {
:root {
--bg-color: black;
--text-color: white;
}
}
Disable Textarea Resizing
Prevent textarea resizing by setting the resize
property to none
.
textarea{
resize:none;
}
back to table of contents
Rainbow Animation
Creates a continuously looping color animation for elements.
button{
animation: rainbow-animation 200ms linear infinite;
}
@keyframes rainbow-animation {
to{
filter: hue-rotate(0deg);
}
from{
filter: hue-rotate(360deg);
}
}
/* If the user prefers reduced motion, then don't use any animations on button */
@media (prefers-reduced-motion: reduce) {
button {
animation: none;
}
}
Note: When working with animations make use of prefers-reduced-motion
media feature to make sure that your website is accessible for the users who may have any vestibular disorders. Give this gem a read written by @tomayac.
See result
data:image/s3,"s3://crabby-images/992d4/992d4cb2c0892592d4d49f2ce87378e8851ff430" alt="hue rotate filter on button"
back to table of contents
Use clamp()
for Responsive Typography
Instead of using media queries for responsive and fluid typography use the clamp()
function.
/* Syntax: clamp(minimum, preferred, maximum) */
h1{
font-size: clamp(2.25rem,6vw,4rem);
}
See result
data:image/s3,"s3://crabby-images/dc5f6/dc5f658d60aa94faa0345230bc152e0729147b7a" alt="font-size changing based on screen size"
back to table of contents
Create A Sticky Footer
You can create a footer
that always stick to the bottom of the browser window with only a few lines of CSS.
<div class='layout'>
<main>
<!-- your content here -->
</main>
<footer>
<!-- your footer content here -->
</footer>
</div>
.layout{
height: 100vh;
display: flex;
flex-direction: column;
}
footer{
margin-top: auto;
}
See result
data:image/s3,"s3://crabby-images/911e5/911e5be605bb76e452ef66e6fa8be6021cfdddf9" alt="sticky footer"
back to table of contents
Contributing
If you have a CSS tip or trick that you'd like to share with the community, I'd love to hear from you!
When submitting a pull request, please be sure to include a detailed description of the tip or trick, along with a code snippet and any relevant images.
back to table of contents
Support
Please consider supporting this project. Your support enables me to continue working on this project and creating more resources in the future.
If you encounter any issues or have questions about this project, please feel free to reach out to me for support. You can contact me via email at [email protected].
back to table of contents
License
This project is licensed under the MIT License.
back to table of contents