• New CSS Features That Are Changing Web Design
  • Original by Zell
  • Translation from: The Gold Project
  • This article is permalink: github.com/xitu/gold-m…
  • Translator: Sophia
  • Proofreader: Kezhenxu94 hannahGu

Today, the landscape of web design has completely changed. We have new and powerful tools — CSS Grids, CSS Custom Properties, CSS Shapes and CSS writing mode, These are just a few examples — all of which can be used to exercise our creativity. Zell Liew explains how we can use them to exercise our creativity.

There was a time when web design became boring. Designers and developers build the same types of sites over and over again, to the point where we are ridiculed by the industry for only building two types of sites:

Is this as far as our “creative” thinking can go? The thought made me feel an uncontrollable sadness.

I hate to admit it, but it was probably the best we could have done at the time. Maybe it’s because we don’t have the right tools for creative design. The needs of the web are growing rapidly, but we are limited by older technologies like floats and tables.

Today, the landscape of web design has completely changed. We have new and powerful tools — CSS Grids, CSS Custom Properties, CSS Shapes and CSS writing mode, We can exercise our creativity with just a few tools.

How does the CSS Grid change everything

You already know that grids are critical to web design. But have you ever stopped to ask yourself how you primarily use grids to design web pages?

Most of us don’t think about it. We usually use the 12-column grid that has become our industry standard.

  • But why do we use the same grid?
  • Why is the grid made up of 12 columns?
  • Why are our grids equal in size?

The reason we might use the same grid is that we don’t want to compute.

In the past, a three column grid was created in a floating based grid. You need to calculate the width of each column, the size of each interval, and how to place the grid items. Then you need to create classes in the HTML to style them appropriately. Doing so is very complicated.

To make things easier, we can use a grid framework. Initially, frames like 960GS and 1440px allowed us to choose grids with 8, 9, 12, or even 16 columns. Later, Bootstrap won the framework war. Because the Bootstrap value only allowed 12 columns for the grid and it was a pain to change this rule, we ended up with 12 columns as the grid standard.

But we shouldn’t blame Bootstrap. It was the best thing to do at the time. Who doesn’t want a good solution that can be achieved with minimal hard work? With the grid problem solved, we turned our attention to other aspects of design, such as typography, color, and accessibility.

Now, with the advent of CSS Grid, grids are much simpler. We no longer need to worry about complex calculations encountered in the grid. The work has become so simple that I think creating grids with CSS is much easier than using a design tool like Sketch!

Why is that?

Suppose you want to make a grid of 4 columns, each 100 pixels in size. Using CSS grids, you can write 100px four times in the grid-template-columns statement, and then a grid of 4 columns will be created.

.grid {
  display: grid;
  grid-template-columns: 100px 100px 100px 100px;
  grid-column-gap: 20px;
}
Copy the code

You can create four grid columns by specifying four column widths in grid-template-columns.

If you want a 12-column grid, you only need to repeat 100px 12 times.

.grid {
  display: grid;
  grid-template-columns: 100px 100px 100px 100px 100px 100px 100px 100px 100px 100px 100px 100px;
  grid-column-gap: 20px;
}
Copy the code

Create a 12-column Grid using CSS Grid.

As you can see, this code isn’t elegant, but we don’t care (yet) about optimizing code quality, we prioritize the design side. CSS Grids are easy for anyone, even a designer with no coding knowledge, to create on the web.

If you want to create grid columns with different widths, just specify the desired widths in the grie-template-columns declaration, and you’re done.

.grid {
  display: grid;
  grid-template-columns: 100px 162px 262px;
  grid-column-gap: 20px;
}
Copy the code

Creating columns of different widths is also a piece of cake.

Make the grid responsive

There is no discussion of CSS grids without discussing their responsiveness. There are several ways to make a CSS Grid responsive. One way (probably the most popular) is to use FR units. Another approach is to change the number of columns in the media query.

Fr is a flexible unit of length that represents a fragment. When you use FR units, the browser splits open space and assigns regions to columns based on FR multiples. This means that to create four columns of the same size, you need to write 1fr four times.

.grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-column-gap: 20px;
}
Copy the code

Grids created with FR units adhere to the maximum width of the grid. (Large view preview)

Let’s do some calculations to understand why the above code creates four equal sized columns.

First, let’s assume that the total available space of the grid is 1260px.

Before assigning width to each column, the CSS Grid needs to know how much space is available (or free). In this case, it subtracted the gripe-gap declaration from 1260px. Since each gap is 20px, we are left with 1200px of free space. (1260 – (20 * 3) = 1200).

Next, consider the FR multiples. In this example, we have four multiples of 1FR, so the browser divides 1200px by four. Each column is 300 px. That’s why we have four equal columns.

However, grids created using FR cells are not always equal!

When you use FR, you need to know that each FR unit is a small fragment of available (or remaining) space.

If your element is wider than any column created using the FR unit, you need to calculate it differently.

For example, the grid in the following example has one large column and three small (but equal) columns, even though it was created using grie-template-columns: 1fr 1fr 1fr 1fr.

See CSS Grid FR Unit Demo 1 by Zell Liew (@Zellwk) on CodePen.

After dividing 1200px into four sections and assigning a 300px area to each 1FR column, the browser realizes that the first grid item contains a 1000px image. Since 1000px is greater than 300px, the browser chooses to assign 1000px to the first column.

That means we need to recalculate the remaining space.

The new free space is 1260px – 1000px – 20px * 3 = 200px; Then divide the 200px by three depending on how much is left. Each part is 66px. I hope this explains why FR units do not always create equiwidth columns.

If you want the fr unit to create a uniform width column every time, you need to use minmax(0, 1fr) to enforce it. For this particular example, you also need to set the image’s max-width property to 100%.

See The CSS Grid FR Unit Demo 2 by Zell Liew (@Zellwk) on CodePen

Note: Rachel Andrew has written about how different CSS values (Min-Content, max-Content, FR, etc.) affect content size. This article is worth reading!

Unequal width grid

You can create grids of varying widths simply by changing the FR multiple. Here is a grid that follows the golden ratio, where the second column is 1.618 times the first column and the third column is 1.618 times the second column.

.grid { display: grid; The grid - the template - the columns: 1 fr 1.618 fr 2.618 fr; grid-column-gap: 1em; }Copy the code

A three-column grid created using the Golden ratio.

Change the mesh at different breakpoints

If you want to change the grid at different breakpoints, you can declare the new grid in the media query.

.grid { display: grid; grid-template-columns: 1fr 1fr; grid-column-gap: 1em; } @media (min-width: 30em) { .grid { grid-template-columns: 1fr 1fr 1fr 1fr; }}Copy the code

Is it difficult to create grids using CSS Grid? If the product managers knew it was that easy, the designers and developers would be dead by now.

Height based mesh

It was not possible to make a grid based on the height of the site because we had no way to get the height of the viewport. Now, with Viewport units, CSS Calc, and CSS Grid, we can even make grids based on viewport height.

In the following demonstration, I created a grid square based on the height of the browser.

See the Height based Grid example for Zell Liew (@Zellwk) on CodePen.

Jen Simmons has a great video on four dimensional space design – using A CSS Grid. I strongly encourage you to check it out.

Placement of grid items

In the past, locating grid items was a pain because you had to compute the margin-left property.

Now, with CSS Grid, you can place Grid items directly using CSS without additional computation.

.grid-item { grid-column: 2; /* put the second column */}Copy the code

Place an item in the second column.

You can even tell how many columns a grid item should occupy by using the span keyword.

.grid-item {/* put it in the second column and span 2 columns */ grid-column: 2 / span 2; }Copy the code

You can use the span keyword to tell you how many columns (or rows) the grid item should occupy.

revelation

CSS Grid enables you to easily lay things out so that you can quickly create many different variations of the same site. A prime example is Lynn Fisher’s personal page.

If you want to learn more about what CSS Grid can do, check out Jen Simmon’s lab, where she will explore how to create different types of layouts using CSS Grid and other tools.

To learn more about CSS Grid, check out the following resources:

  • Master CSS Grid, Rachel Andrew and Jen Simmons video tutorials
  • Layout Land, a series of videos on layouts by Jen Simmons
  • CSS Layout Workshop with Rachel Andrew
  • Learn CSS Grid, a free course on CSS Grids by Jonathan Suh
  • Grid Critters, Dave Geddes A fun way to learn about CSS Grids

Design with irregular shapes

We are used to creating rectangular layouts on web pages because the CSS box model is a rectangle. In addition to rectangles we found ways to create simple shapes such as triangles and circles.

Today, we don’t need to stop because creating irregular shapes is too much trouble. Using CSS shapes and clip-path, we can create irregular shapes effortlessly.

For example, Aysha Anggraini tried to create a comic-strip-inspired layout using a CSS Grid and clip path.

<div class="wrapper">
  <div class="news-item hero-item">
  </div>
  <div class="news-item standard-item">
  </div>
  <div class="news-item standard-item">
  </div>
  <div class="news-item standard-item">
  </div>
</div>
Copy the code
.wrapper { display: grid; grid-gap: 10px; grid-template-columns: repeat(2, 1fr); grid-auto-rows: 1fr; max-width: 1440px; font-size: 0; } .hero-item, .standard-item { background-position: center center; background-repeat: no-repeat; background-size: cover; } .news-item { display: inline-block; min-height: 400px; width: 50%; } .hero-item { background-image: url('https://s3-us-west-2.amazonaws.com/s.cdpn.io/53819/divinity-ori-sin.jpg'); } .standard-item:nth-child(2) { background-image: url("https://s3-us-west-2.amazonaws.com/s.cdpn.io/53819/re7-chris-large.jpg"); } .standard-item:nth-child(3) { background-image: url("https://s3-us-west-2.amazonaws.com/s.cdpn.io/53819/bioshock-large.jpg"); } .standard-item:nth-child(4) { background-image: url("https://s3-us-west-2.amazonaws.com/s.cdpn.io/53819/dishonored-large.jpg"); } @supports (display: grid) { .news-item { width: auto; min-height: 0; } .hero-item { grid-column: 1 / span 2; grid-row: 1 / 50; -webkit-clip-path: polygon(0 0, 100% 0, 100% calc(100% - 75px), 0 100%); clip-path: polygon(0 0, 100% 0, 100% calc(100% - 75px), 0 100%); } .standard-item:nth-child(2) { grid-column: 1 / span 1; grid-row: 50 / 100; -webkit-clip-path: polygon(0 14%, 0 86%, 90% 81%, 100% 6%); clip-path: polygon(0 14%, 0 86%, 90% 81%, 100% 6%); margin-top: -73px; } .standard-item:nth-child(3) { grid-column: 2 / span 1; grid-row: 50 / 100; -webkit-clip-path: polygon(13% 6%, 4% 84%, 100% 100%, 100% 0%); clip-path: polygon(13% 6%, 4% 84%, 100% 100%, 100% 0%); margin-top: -73px; margin-left: -15%; margin-bottom: 18px; } .standard-item:nth-child(4) { grid-column: 1 / span 2; grid-row: 100 / 150; -webkit-clip-path: polygon(45% 0, 100% 15%, 100% 100%, 0 100%, 0 5%); clip-path: polygon(45% 0, 100% 15%, 100% 100%, 0 100%, 0 5%); margin-top: -107px; }}Copy the code

See comic-book-style Layout with CSS Grid by Aysha Anggraini (@rrenula) on CodePen.

Hui Jing explains how to use CSS shapes to enable text to flow along Beyonce’s curves.

Text can flow around Beyonce if you like!

If you want to dig deeper, Sara Soueidan’s post can help you create non-rectangular layouts.

CSS shapes and clip-paths give you unlimited possibilities to create custom shapes that are unique to your design. Unfortunately, syntactically, CSS shapes and clip-paths are not as intuitive as CSS Grids. Fortunately, we have things like Clippy and Firefox’s Shape Path Editor to help us create the shapes we want.

Clippy helps you easily create custom shapes using clip-path.

Using CSSwriting-modeToggle text streams

We’re used to seeing left-to-right typography on the Web because the web was originally made primarily for English speakers.

But some languages are not formatted in this direction. For example, Chinese can be read from top to bottom or from right to left.

The writing-mode of CSS allows text to flow in the direction native to each language. Hui Jing experimented with a Chinese-style layout, flowing from right to left on a site called Penang Hokkien from top to bottom. You can read more About her experiments in her article “The One About Home.”

In addition to the articles, Hui Jing gave a wonderful presentation on typography and writing-mode, “When East Meets West: Web Typography and How It Can Inspire Modern Layouts “. I highly recommend you watch it.

The people of Penang Hokkien show that Chinese texts can be written from top to bottom and right to left.

Even if you don’t design a language like Chinese, that doesn’t mean you can’t apply CSS writing-mode to English. Back in 2016, when I created Devfest. Asia, I had an Epiphany and chose to use writing-mode to rotate the text.

The tags are created using writing-mode and transformations.

Jen Simmons’ lab also contains many experiments on writing-mode. I highly recommend you take a look at it.

Jen Simmon’s lab image shows Jan Tschichold.

Hard work and creativity can get people far

While the new CSS tools are helpful, you don’t necessarily need any of them to create a unique site. A little ingenuity and a little effort goes a long way.

For example, in the Super Silly Hackathon, Cheeaun rotates the entire site -15 degrees, making you look like a fool while reading the site.

If you want to enter the Super Silly Hackathon, Cheeaun will make sure you look Silly.

Darin Senneff made an animated login avatar with some triangles and GSAP. See how cute this ape is and how it covers your eyes when your mouse cursor is over the password box. Kawaii!

When I created the sales page for my Learn JavaScript course, I added elements that made JavaScript learners feel at home.

Instead of writing information about a course package normally, I use the function syntax to create the course package.

conclusion

Unique web design is not just about layout design, it’s about how the design integrates with the content. With a little effort and creativity, all of us can create unique designs and advertise them, and the tools we have at our disposal today make our job easier.

The question is, do you care enough about making a unique design? I hope you are.

If you find any errors in the translation or other areas that need improvement, you are welcome to revise and PR the translation in the Gold Translation program, and you can also get corresponding bonus points. The permanent link to this article at the beginning of this article is the MarkDown link to this article on GitHub.


Diggings translation project is a community for translating quality Internet technical articles from diggings English sharing articles. The content covers the fields of Android, iOS, front end, back end, blockchain, products, design, artificial intelligence and so on. For more high-quality translations, please keep paying attention to The Translation Project, official weibo and zhihu column.