Udacity - Responsive Web Design

170201 유다시티

Responsive Web Design Fundamentals

컴퓨터보다 모바일을 더 많이 이용하는 세상이다. 그러므로 response design을 하지 않으면 안된다. 다양한 기기의 size별로 적용이 되도록 해야한다.

Simulator / Emulator

Emulator는 한 시스템에서 다른 시스템을 복제한다. 그리하여 두 번째 시스템이 첫 번째 시스템을 따라 행동하는 것이다. 외부의 행동에 대해 똑같이 따라하려고 하는 이 관점은 시뮬레이션과는 정 반대이다. 왜냐하면, 시뮬레이션은 자주 내부 상태와 관련하여, 흉내내는 시스템의 추상적인 모델과 관계가 있기 때문이다. Simulation은 실제로 실행하기 어려운 실험을 간단히 행하는 모의실험을 뜻한다.

  • crome Web Development : ⌘+⌥+j

Pixels

  • Device Independent Pixels

  • Hardware Pixels

Hardware Pixels / DPR = DIP

setting the viewport

<meta name="viewport" content="width=device-width,initial=scale=1">

viewport를 셋팅하는 것을 잊지마라!

CSS는 viewport가 overview되는 것을 허락한다.

img, embed, object, video {
	max-width: 100%
}

를 설정해주는 것을 추천한다.

적어도 클릭(보여야)하는건 48px는 되어야한다.

button {
	min-width: 48px;
	min-height: 48px;
}

https://www.w3.org/community/webed/wiki/CSS/Properties#Border

Stylesheet

<link rel="stylesheet" media="screen and (min-width: 500px)" href="name.css">

media

@media screen and (min-width: 500px){
	body{background-color: green;}
}

@import url("no.css") only screen and (min-width: 500px);

import tag는 피해라!

min-devise-widthmax-devise-width의 사용을 피해라. 왜냐하면 기계의 화면의 값을 가져오는 것인데 안드로이드의 경우에는 잘못된 값을 반환하는 경우도 있다.

Breakpoints

: the point a which your sites content will respond to provide the user with the best possible layout to consume the information.

  • breakpoint를 어디에 설정해야하나요? based on specific devices, products, brand names or anything else, will almost always result in a maintenance nigthmare.

breakpoint는 발견하는 것이다.

Flexbox

display: flex;
flex-wrap: wrap;

flex는 row가 기준이다. flex-wrap: wrap은 가려지는 경우 다음줄로!

header{ width: 100%; order: 1;}
.red{ width: 50%; order:2; }

order은 나타나는 순서를 나타낸다.

Patterns

  1. Mostly Fluid

 <div class="container">
 	<div class="box dark_blue"></div>
 	<div class="box light_blue"></div>
 	<div class="box green"></div>
 	<div class="box red"></div>
 	<div class="box orange"></div>
 </div>
.container{
	display: flex;
	flex-wrap: wrap;
}
.box{
	width: 100%;
}
@media screen and (min-width: 450px){
	.light_blue, .green{
    	width: 50%;
    }
}
@media screen and (min-width: 550px){
	.dark_blue, .light_blue,{
    	width: 50%;
    }
     .green, .red, .orange{
     	width: 33.333333%;
     }
}
@media screen and (min-width: 700px){
	.container{
		width: 700px;
		margin-left: auto;
		margin-right: auto;
	}
}
  1. Layout Shifter

<div class="container">
	<div class="box dark_blue"></div>
	<div class="container" id="container2">
		<div class="box light_blue"></div>
		<div class="box green"></div>
	</div>
	<div class="box red"></div>
</div>
.container{
	width: 100%;
	display: flex;
	flex-wrap: wrap;
}
.box{
	width: 100%;
}
@media screen and (min-width: 500px){
	.dark_blue{
    	width: 50%;
    }
    #container2{
    	width: 50%;
    }
}
@media screen and (min-width: 600px){
	.dark_blue{
    	width: 25%;
        order: 1;
    }
    #container2{
    	width: 50%;
    }
    .red{
    	width: 25%;
        order: -1;
    }
}
  1. Column Drop

<div class="container">
	<div class="box dark_blue"></div>
	<div class="box light_blue"></div>
	<div class="box green"></div>
</div>
.container{
	display: flex;
	flex-wrap: wrap;
}
.box{
	width: 100%;
}
@media screen and (min-width: 450px){
	.dark_blue{
    	width: 25%;
    }
    .light_blue{
    	width: 75%;
    }
}
@media screen and (min-width: 550px){
	.dark_blue, .green{
    	width: 25%;
    }
    .light_blue{
    	width: 50%;
    }
}
  1. Off Canvas

menu.addEventListener('click', function(e) {
  drawer.classList.toggle('open');
  e.stopPropagation();
});
nav {
  width: 300px;
  position: absolute;
  /* This trasform moves the drawer off canvas. */
  -webkit-transform: translate(-300px, 0);
  transform: translate(-300px, 0);
  /* Optionally, we animate the drawer. */
  transition: transform 0.3s ease;
}
nav.open {
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}
@media screen and (min-width: 600px){
	nav{
 		position: relative;
 		transform: translate(0,0);
    }
    body{
    	display: flex;
    	flex-flow: row nowrap;
    }
    main{
    	width: auto;
    	flex-grow: 1;
    }
}

Responsive Tables

  • Hidden Column : display: none;은 보여지지 않게 숨기는 것.

  • No More Tables :

      table {
       border: 1px solid #ddd;
     }
     tr:nth-child(odd) {
       background-color: #f9f9f9;
     }
     @media screen and (max-width: 500px) {
       table, thead, tbody, th, td, tr {
         display: block;
       }
       thead tr {
         position: absolute;
         top: -9999px;
         left: -9999px;
       }
       td {
         position: relative;
         padding-left: 50%;
       }
       td:before {
         position: absolute;
         left: 6px;
         content: attr(data-th);
         font-weight: bold;
       }
       td:first-of-type {
         font-weight: bold;
       }
     }
     ```
     ```css
           td {
       min-width: 75px;
       text-align: center;
     }
     th:first-of-type {
       min-width: 125px;
     }
     div {
       width: 50%;
       overflow-x: auto;
     }
     ```

### Minor BreakPoints
:fontsize, icon size과 같은 사소한 변화

Last updated