From 767460863964858144a19c599825308d104aae97 Mon Sep 17 00:00:00 2001 From: androiddrew Date: Mon, 18 Feb 2019 14:23:05 -0500 Subject: [PATCH] Initial commit --- Net_mag_tut/app.css | 65 ++++++++++++++++++++++ Net_mag_tut/index.html | 18 ++++++ README.md | 79 ++++++++++++++++++++++++++ dashboard_ex/index.html | 120 ++++++++++++++++++++++++++++++++++++++++ scrimba_tut/README.md | 6 ++ scrimba_tut/basic.css | 31 +++++++++++ scrimba_tut/index.css | 21 +++++++ scrimba_tut/index.html | 14 +++++ 8 files changed, 354 insertions(+) create mode 100644 Net_mag_tut/app.css create mode 100644 Net_mag_tut/index.html create mode 100644 README.md create mode 100644 dashboard_ex/index.html create mode 100644 scrimba_tut/README.md create mode 100644 scrimba_tut/basic.css create mode 100644 scrimba_tut/index.css create mode 100644 scrimba_tut/index.html diff --git a/Net_mag_tut/app.css b/Net_mag_tut/app.css new file mode 100644 index 0000000..45f6835 --- /dev/null +++ b/Net_mag_tut/app.css @@ -0,0 +1,65 @@ +* { + box-sizing: border-box; + margin: 0; + padding: 0; +} + +html { + font-size: 10px; +} + +body { + margin: 0; + font-size: 1.6rem; + font-family: Helvetica; +} + +#container { + width: 100vw; + height: 100vh; +} + +.grid { + display: grid; + grid-template-columns: repeat(4, 1fr); + /* grid-template-rows: repeat(4, 75px); */ + grid-template-rows: 70px 1fr 1fr 1fr 1fr 140px; +} + +#item1 { + background-color: purple; + grid-column-start: 2; + grid-column-end: 4; + grid-row-start: 3; + grid-row-end: -2; +} + +#item2 { + background-color: green; + grid-column: 3; + grid-row: 1; +} + + +/* +Size can be any valid CSS unit px vw auto that enables a column or row to +stretch across available space + +For example grid-template-column: 10px auto will create a 10px column followed +by a second column that fills all available space + +fr is a fractional unit that causes any remaining space to be distributed +to columns or rows based on the ratios of these units + + grid-template-rows: 1fr 2fr + +creates two dynamic rows whith the second twice the size of the first, + + grid-template-columns: 1fr 1fr 1fr 1fr + +Defines four equal-sized columns + +The `repeat()`function can be used to make the above less verbose repeat(4, 1fr) + + +*/ diff --git a/Net_mag_tut/index.html b/Net_mag_tut/index.html new file mode 100644 index 0000000..61eca2e --- /dev/null +++ b/Net_mag_tut/index.html @@ -0,0 +1,18 @@ + + + + + CSS Grid Demo + + + +
+
+ Item 1 contents +
+
+ Item 2 contents +
+
+ + diff --git a/README.md b/README.md new file mode 100644 index 0000000..0f50425 --- /dev/null +++ b/README.md @@ -0,0 +1,79 @@ +# CSS Grid + +This repo houses a number of tutorials for using CSS Grid. + + +## Using the grid + + +Size can be any valid CSS unit `px`, `vw`, `auto` that enables a column or row to stretch across available space + +For example `grid-template-column: 10px auto` will create a 10px column followed by a second column that fills all available space + +`fr` is a fractional unit that causes any remaining space to be distributed to columns or rows based on the ratios of these units +``` +grid-template-rows: 1fr 2fr +``` +creates two dynamic rows with the second twice the size of the first, +``` +grid-template-columns: 1fr 1fr 1fr 1fr +``` +Defines four equal-sized columns + +The `repeat()`function can be used to make the above less verbose `repeat(4, 1fr)` + + +## More complex layouts + +Grids with unequal sized cells can be created by combining the different units mentioned. We can also use the `minmax()` function to define a minimum and a maximum size for dynamic columns and rows. + +``` +grid-template-rows: 40px 2fr repeat(2, minmax(75px, 1fr)) +``` + +Creates four rows with the first 40px tall, the other three stretch over remaining space in a 2:1:1 ratio. The last two having a minimum height of 75px which sets the minimum height of the second row at 150px. + +## Layout + +### Accessing the grid + +*INSERT IMAGE OF GRID LINES* + +We can consider this now to be a 2 x 2 array indexed at 1 and accessible with a negative index if necessary. For example a 4 x 4 Grid will have the first column accessible at either index 1 or -5. They can be used as the boundary lines for elements placed in them. + +*NOTE* We can also assign a name to index by adding a string in square brackets in the property declarations + +``` +gird-template-rows: [first-row] 1fr [second-row] 1fr [last] +``` + +### Positioning elements inside the grid + +*THIS IS GONNA HAVE TO BE REWRITTEN* + +Similar to flexbox, the horizontal and vertical position of items placed in the grid can be controlled by setting `justify-items` and `align-items` respectively to `start`, `center`, or `stretch`. + +The same control of grid column and row positions with in a larger container (grid inside a grid) can be applied used the `justify-content` and `align-content` properties and the `start`, `center`, or `stretch` values. The additional value `space-between` or `space-around` is used to divide extra space between columns/rows. `space-evenly` can used to divide extra space evenly between columns/rows with the same or half the amount of space on the ends. + +We can also define `align-content` and `justify-content`(in that order) using `place-content`. Values of `align-items` and `justify-items` can be defined with `place-items` *WTF THIS GUY CAN'T WRITE* + + +### Positioning items in the Grid using line numbers + +To place an item in the grid we can set it's `grid-column-start` and `grid-column-end` properties between which the item should be stretched. For rows the properties are `grid-row-start` and `grid-row-end` + +``` +#item1 { + grid-column-start: 2; + grid-column-end: 4; + grid-row-start: 3; + grid-row-end: -1; +} + +#item2 { + grid-column: 3; + grid-row: 1; +} + + +``` diff --git a/dashboard_ex/index.html b/dashboard_ex/index.html new file mode 100644 index 0000000..f5e2d68 --- /dev/null +++ b/dashboard_ex/index.html @@ -0,0 +1,120 @@ + + + + + + Grid Tutorial + + + +
+
+ +
+ +
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
+ +
+ + diff --git a/scrimba_tut/README.md b/scrimba_tut/README.md new file mode 100644 index 0000000..4f12138 --- /dev/null +++ b/scrimba_tut/README.md @@ -0,0 +1,6 @@ +# Scrimba Tutorial + + +Source: + +https://scrimba.com/g/gR8PTE \ No newline at end of file diff --git a/scrimba_tut/basic.css b/scrimba_tut/basic.css new file mode 100644 index 0000000..aab9abf --- /dev/null +++ b/scrimba_tut/basic.css @@ -0,0 +1,31 @@ +.container > div { + display: flex; + justify-content: center; + align-items: center; + font-size: 2em; + color: #ffeead; +} + +html, body { + box-sizing: border-box; + background-color: #ffeead; + height: 100%; + padding: 10px; + margin: 0px; +} + +.container > div:nth-child(1n) { + background-color: #96ceb4; +} + +.container > div:nth-child(3n) { + background-color: #88d8b0; +} + +.container > div:nth-child(2n) { + background-color: #ff6f69; +} + +.container > div:nth-child(4n) { + background-color: #ffcc5c; +} diff --git a/scrimba_tut/index.css b/scrimba_tut/index.css new file mode 100644 index 0000000..d228862 --- /dev/null +++ b/scrimba_tut/index.css @@ -0,0 +1,21 @@ +.container { + height: 100%; + display: grid; + grid-gap: 3px; + grid-template-columns: repeat(12, 1fr); + grid-template-rows: 40px auto 40px; +} + +.header { + grid-column: 1 / -1; +} + +.menu {} + +.content { + grid-column: 2 / -1; +} + +.footer { + grid-column: 1 / -1; +} diff --git a/scrimba_tut/index.html b/scrimba_tut/index.html new file mode 100644 index 0000000..6af80cc --- /dev/null +++ b/scrimba_tut/index.html @@ -0,0 +1,14 @@ + + + + + + +
+
HEADER
+ +
CONTENT
+ +
+ +