[js+css] 상하좌우 요소 만들기
css에 :before, :after 같은 가상선택자는 왜 2개밖에 없을까?
div 안에 상하좌우 absolute인 요소를 만들어야 하는데, 여러(?) 방법 중 고민하다 그냥 map 돌려서 요소 4개를 만들기로..
1
2
3
4
5
6
7
{
  ["top", "bottom"].map((vertical) => {
    return ["left", "right"].map((horizon) => {
      return <span className={`area-frame ${vertical} ${horizon}`} />;
    });
  });
}
결과물 ⬇️
1
2
3
4
<span class="area top left"></span>
<span class="area top right"></span>
<span class="area bottom left"></span>
<span class="area bottom right"></span>
scss ⬇️
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
.area {
  position: absolute;
  width: 10vw;
  height: 10vw;
  &.top {
    top: 0;
    border-top: 4px solid #fff;
  }
  &.bottom {
    bottom: 0;
    border-bottom: 4px solid #fff;
  }
  &.left {
    left: 0;
    border-left: 4px solid #fff;
  }
  &.right {
    right: 0;
    border-right: 4px solid #fff;
  }
}
 This post is licensed under  CC BY 4.0  by the author.