<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: eakers21008</title>
    <description>The latest articles on DEV Community by eakers21008 (@eakers21008).</description>
    <link>https://dev.to/eakers21008</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F494293%2F2a97d275-b49a-44ab-9cba-688a022eb90d.jpeg</url>
      <title>DEV Community: eakers21008</title>
      <link>https://dev.to/eakers21008</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/eakers21008"/>
    <language>en</language>
    <item>
      <title>Introduction to CSS Grid</title>
      <dc:creator>eakers21008</dc:creator>
      <pubDate>Thu, 22 Oct 2020 15:49:20 +0000</pubDate>
      <link>https://dev.to/eakers21008/introduction-to-css-grid-5feb</link>
      <guid>https://dev.to/eakers21008/introduction-to-css-grid-5feb</guid>
      <description>&lt;p&gt;In this post, We will go over the CSS Grid, and how to apply it to your projects! &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Introduction&lt;/strong&gt;&lt;br&gt;
CSS Grid is a layout framework that helps you position specific items within your web Page. But, Unlike Bootstrap and Flexbox, CSS Grid is baked into vanilla CSS and HTML, simplifying the entire process. It's supported by most browsers, making it extremely useful for making a page available on all platforms. &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Definitions&lt;/strong&gt;&lt;br&gt;
Grid Container: A CSS attribute that creates a new CSS grid within the page.&lt;/p&gt;

&lt;p&gt;Grid Items: Includes all items within the Container, including: rows, columns, row lines, and column lines.&lt;/p&gt;

&lt;p&gt;Display Property: allows the created CSS grid to be displayed on the page. &lt;/p&gt;

&lt;p&gt;CSS Grid also allows for a more precise positioning of items on a webpage because it is able to move items in two dimensions, instead of flexbox's one dimension. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fww76encg7jkdpxs2qpya.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fww76encg7jkdpxs2qpya.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;In order to apply CSS grid to your project, you must create a &lt;strong&gt;container&lt;/strong&gt; div around the attributes you would like to edit.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight html"&gt;&lt;code&gt;&lt;span class="nt"&gt;&amp;lt;body&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;div&lt;/span&gt; &lt;span class="na"&gt;class=&lt;/span&gt;&lt;span class="s"&gt;"container"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;
   */Page Children */
  &lt;span class="nt"&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;/body&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Once this is done within your index.html, you can now move on to editing your stylesheet.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Basic CSS Grid Syntax&lt;/strong&gt;&lt;br&gt;
CSS Grid Syntax can be divided into three main groups: &lt;strong&gt;Rows, Columns, and spaces between columns&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Display Attribute&lt;/strong&gt;&lt;br&gt;
To create a new instance of CSS Grid, you must specify what type you would like using the Display method.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight css"&gt;&lt;code&gt;&lt;span class="nc"&gt;.container&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="nl"&gt;display&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;grid&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;grid&lt;/strong&gt; – generates a block-level grid&lt;br&gt;
&lt;strong&gt;inline-grid&lt;/strong&gt; – generates an inline-level grid&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Grid Templates: Columns and Rows&lt;/strong&gt;&lt;br&gt;
Grid Columns and Grid Rows are defined as shown, using letters a, b and c as placeholders for values:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight css"&gt;&lt;code&gt;&lt;span class="nc"&gt;.container&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="nl"&gt;display&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;grid&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="py"&gt;grid-template-columns&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;a&lt;/span&gt; &lt;span class="n"&gt;b&lt;/span&gt; &lt;span class="n"&gt;c&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="py"&gt;grid-template-rows&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;a&lt;/span&gt; &lt;span class="n"&gt;b&lt;/span&gt; &lt;span class="n"&gt;c&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;With both grid templates, the number represents a row or column size, while the number of values represents the number of rows or columns. &lt;/p&gt;

&lt;p&gt;For example, the statement 'grid-template-columns: 200px 200px 200px;' would create a grid with 3 columns, each 200px in size. &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Grid Positioning and Formatting&lt;/strong&gt;&lt;br&gt;
Gaps between grid items can simply be formatted with the following code:&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F5n2p7j796st3ljy4zumw.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F5n2p7j796st3ljy4zumw.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
&lt;strong&gt;grid-row and grid-column gap&lt;/strong&gt; simply control how large of a gap you would like between each item in your container.&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F1ursafj40lbm4kldspx8.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F1ursafj40lbm4kldspx8.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Positioning your grid can simply be done with the following lines:&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fwjxzet2753kkujrgy9o5.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fwjxzet2753kkujrgy9o5.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
Code to position the grid is similar to what you will find using flexbox, but in a simpler, 3 dimensional package.&lt;br&gt;
You can also edit the size of an object to span more than one grid section using these lines:&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fj529p5priui6hw04jkbk.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fj529p5priui6hw04jkbk.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
This code essentially defines the image as taking up multiple cells of the Grid.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real World Application&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Here's a real world example of CSS Grid. This is a quick gallery that I put together: &lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fpp6gvfyn22suz1swu5qc.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fpp6gvfyn22suz1swu5qc.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
Here is the CSS that makes it all work:&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F7ows5xurh970r6k9tbqw.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F7ows5xurh970r6k9tbqw.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
In this snippet, the &lt;strong&gt;display:grid;&lt;/strong&gt; attribute is used to define the container &lt;strong&gt;picGallery&lt;/strong&gt; as using CSS Grid. the columns and rows are defined as being a 3 column 3 row grid, using the fraction 'fr' to divide the grid. Finally, gaps between items are defined by the row and column grid gap attributes, and the centering is taken care of by 'justify-items'.&lt;/p&gt;

</description>
    </item>
  </channel>
</rss>
