다음 사항에 유의하시기 바랍니다.
- 세 가지 새로운 CSS 기능을 사용하면 매끄러운 시작 및 종료 애니메이션을 쉽게 추가할 수 있습니다.
- 배열 그룹화를 사용하여 고차 데이터 세트 계산
- DevTools를 사용하면 로컬 재정의를 더 쉽게 수행할 수 있습니다.
- 그 외에도 다양한 기능이 있습니다.
저는 아드리아나 자라입니다. 자세히 살펴보고 Chrome 117의 개발자를 위한 새로운 기능을 살펴보겠습니다.
시작 및 종료 애니메이션을 위한 새로운 CSS 기능
이 세 가지 새로운 CSS 기능이 설정을 완료해 들어가기 및 나가기 애니메이션을 쉽게 추가할 수 있습니다. 대화상자나 팝오버와 같이 닫을 수 있는 요소로 상단 레이어에서 부드럽게 애니메이션으로 이동합니다.
첫 번째 특성은 transition-behavior
입니다. display
와 같은 불연속 속성을 전환하려면 transition-behavior
에 allow-discrete
값을 사용하세요.
.card {
transition: opacity 0.25s, display 0.25s;
transition-behavior: allow-discrete; /* Note: be sure to write this after the shorthand */
}
.card.fade-out {
opacity: 0;
display: none;
}
그런 다음 @starting-style
규칙을 사용하여 항목 효과를 display: none
에서 최상위 레이어로 애니메이션 처리합니다. @starting-style
를 사용하여 페이지에서 요소가 열리기 전에 브라우저에서 조회할 수 있는 스타일을 적용합니다.
/* 0. BEFORE-OPEN STATE */
/* Starting point for the transition */
@starting-style {
.item {
opacity: 0;
height: 0;
}
}
/* 1. IS-OPEN STATE */
/* The state at which the element is open + transition logic */
.item {
height: 3rem;
display: grid;
overflow: hidden;
transition: opacity 0.5s, transform 0.5s, height 0.5s, display 0.5s allow-discrete;
}
/* 2. EXITING STATE */
/* While it is deleting, before DOM removal in JS, apply this
transformation for height, opacity, and a transform which
skews the element and moves it to the left before setting
it to display: none */
.is-deleting {
opacity: 0;
height: 0;
display: none;
transform: skewX(50deg) translateX(-25vw);
}
마지막으로 상단 레이어에서 popover
또는 dialog
를 페이드아웃하려면 overlay
속성을 전환 목록에 추가합니다. 나머지 지형지물과 함께 오버레이에 애니메이션을 적용하고 애니메이션을 적용할 때 오버레이가 상단 레이어에 유지되도록 전환 또는 애니메이션에 오버레이를 포함합니다. 그러면 훨씬 부드럽게 표시됩니다.
[open] {
transition: opacity 1s, display 1s allow-discrete;
}
[open] {
transition: opacity 1s, display 1s allow-discrete, overlay 1s allow-discrete;
}
모션으로 사용자 환경을 개선하기 위해 이러한 기능을 사용하는 방법에 대한 자세한 내용은 원활한 시작 및 종료 애니메이션을 위한 4가지 새로운 CSS 기능을 참조하세요.
배열 그룹화
프로그래밍에서 배열 그룹화는 매우 일반적인 작업으로, SQL의 GROUP BY 절 및 맵리듀스 프로그래밍 (map-group-reduce)을 사용할 때 가장 자주 나타납니다.
데이터를 그룹으로 결합하는 기능을 통해 개발자는 고차 데이터 세트를 계산할 수 있습니다. 예를 들어 동질 집단의 평균 연령 또는 웹페이지의 일일 LCP 값이 있습니다.
배열 그룹화는 Object.groupBy
및 Map.groupBy
정적 메서드를 추가하여 이러한 시나리오를 지원합니다.
groupBy
는 반복 가능 항목의 각 요소에 대해 한 번씩 제공된 콜백 함수를 호출합니다. 콜백 함수는 연결된 요소의 그룹을 나타내는 문자열 또는 기호를 반환해야 합니다.
다음 예의 MDN 문서에는 제품 배열을 반환하는 데 사용된 groupBy
메서드가 있는 제품 배열이 유형별로 그룹화되어 있습니다.
const inventory = [
{ name: "asparagus", type: "vegetables", quantity: 5 },
{ name: "bananas", type: "fruit", quantity: 0 },
{ name: "goat", type: "meat", quantity: 23 },
{ name: "cherries", type: "fruit", quantity: 5 },
{ name: "fish", type: "meat", quantity: 22 },
];
const result = Object.groupBy(inventory, ({ type }) => type);
/* Result is:
{
vegetables: [
{ name: 'asparagus', type: 'vegetables', quantity: 5 },
],
fruit: [
{ name: "bananas", type: "fruit", quantity: 0 },
{ name: "cherries", type: "fruit", quantity: 5 }
],
meat: [
{ name: "goat", type: "meat", quantity: 23 },
{ name: "fish", type: "meat", quantity: 22 }
]
}
*/
자세한 내용은 groupBy
문서를 참고하세요.
DevTools에서 로컬 재정의가 간소화되었습니다.
이제 로컬 재정의 기능이 간소화되어 이에 액세스하지 않고도 Network 패널에서 원격 리소스의 응답 헤더와 웹 콘텐츠를 쉽게 모의 처리할 수 있습니다.
웹 콘텐츠를 재정의하려면 네트워크 패널을 열고 요청을 마우스 오른쪽 버튼으로 클릭한 다음 콘텐츠 재정의를 선택합니다.
로컬 재정의를 설정했지만 비활성화한 경우 DevTools가 이를 사용 설정합니다. 아직 설정하지 않았다면 DevTools가 상단의 작업 모음에 메시지를 표시합니다. 재정의를 저장할 폴더를 선택하고 DevTools가 해당 폴더에 액세스하도록 허용합니다.
재정의가 설정되면 DevTools는 소스 > 재정의 > 편집기를 사용하면 웹 콘텐츠를 재정의할 수 있습니다.
재정의된 리소스는 Network 패널에 로 표시됩니다. 아이콘 위로 마우스를 가져가면 재정의된 내용을 확인할 수 있습니다.
Chrome 117의 DevTools에 관한 자세한 내용과 자세한 내용은 DevTools의 새로운 기능을 확인하세요.
그 외에도 다양한 기능 제공
물론 이 외에도 더 많은 기능이 있습니다.
grid-template-columns
및grid-template-rows
에 많은 기대를 받는subgrid
값이 이제 Chrome에서 구현되었습니다.WebSQL
지원 중단 기능 트라이얼과unload
이벤트 지원 중단을 위한 개발자 트라이얼이 있습니다.
추가 자료
여기에서는 몇 가지 주요 사항만 다룹니다. 아래 링크에서 Chrome 117의 추가 변경사항
- Chrome DevTools의 새로운 기능 (117)
- Chrome 117 지원 중단 및 삭제
- Chrome 117의 ChromeStatus.com 업데이트
- Chromium 소스 저장소 변경사항 목록
- Chrome 출시 캘린더
구독
최신 소식을 받아보려면 Chrome 개발자 YouTube 채널 새 동영상이 게시될 때마다 이메일 알림을 받게 됩니다.
아드리아나 자라님, Chrome 117이 출시되면 바로 Chrome의 새로운 기능을 알려드리겠습니다.