최근에 나는 예술적 재능이 부족한 코딩 영감을 찾았습니다. 내 접근? 깨끗하고 간결한 코드에 중점을 둔 다른 사람들의 시각적으로 매력적인 창조물을 복제합니다. 이 캔디 유령 버튼은 내 눈을 사로 잡았습니다!
그들은 빠른 프로젝트에 완벽 해 보였다. 15 분 안에 나는 이것을 Chromium에서 달성했다.
이 기술은 공유 할 가치가 있습니다. 이 기사에서는 내 프로세스를 자세히 설명하고 대체 접근법을 탐색합니다.
초기 설정
간단한 버튼 요소는 기본을 형성하여 이모티콘 삽입을위한 data-ico
속성과 스타일 속성의 정지 목록에 대한 사용자 정의 CSS 속성 --slist
통합합니다.
<code>boo!</code>
항아리 이후 완료, 나는 Safari의 상당한 클리핑-텍스트 제한을 발견했습니다. 버튼 요소, display: flex
(및 아마도 그리드) 요소 및 하위 요소 텍스트에 실패합니다. 결과적으로, 여기에 설명 된 기술은 사파리-무적이다. 해결 방법은 a<span></span>
버튼 내에서 모든 버튼 스타일을<span></span>
, 부모의 국경 박스를 덮는 것. 실제 Apple 장치 액세스가없는 Linux 사용자의 경우 주현절을 권장합니다 (감사합니다, Brian!).
CSS는 아이콘에 대한 ::after
요소와 텍스트/아이콘 정렬에 대한 그리드 레이아웃을 사용합니다. 테두리, 패딩, 국경-라디우스, 대각선 기울기의 --slist
슬랫 스톱리스트 및 글꼴 스타일도 적용됩니다.
<code>button { display: grid; grid-auto-flow: column; grid-gap: .5em; border: solid .25em transparent; padding: 1em 1.5em; border-radius: 9em; background: linear-gradient(to right bottom, var(--slist)) border-box; font: 700 1.5em/ 1.25 ubuntu, sans-serif; text-transform: uppercase; &::after { content: attr(data-ico) } }</code>
위의 코드에 대한 설명 : background-origin
및 background-clip
border-box
로 설정됩니다. background-origin
핀은 지정된 상자의 왼쪽 상단에 background-position
의 0,0 점을 배경으로 background-size
에 대한 참조를 결정합니다. border-box
그라디언트가 전체 테두리 박스에 걸쳐 보장합니다. 기본 padding-box
그라디언트가 패딩 영역을 덮는 것만 커버합니다.
크롬-특이 적 용액 (비표준)
이 방법은 3 개의 마스크 층과 합성을 사용합니다. 마스크 컴포팅의 리프레셔는 [Crash Course 링크]에서 찾을 수 있습니다. CSS 마스크 층에서는 알파 채널 만 중요합니다. RGB 채널은 결과에 영향을 미치지 않습니다.
우리는 두 개의 층으로 시작합니다 : 테두리 박스 (Alpha = 1)를 덮는 완전히 불투명 한 층과 1 초, 또한 패딩 박스 (alpha = 1)로 제한된 완전히 불투명 한 층도 있습니다.
레이아웃 상자를 중첩 사각형으로 시각화하십시오. 하단 층은 테두리 박스를 통해 완전히 불투명합니다. 상단 층은 패딩 박스 내에서 불투명하고 국경 영역에서 투명합니다. 코너 반올림은 border-radius
(및 패딩 박스의 border-width
)에 의해 결정됩니다.
이 층은 exclude
Operation (또는 WebKit의 xor
)을 사용하여 합성됩니다. 결과 : 패딩 박스 내에서 알파 = 0 (두 층 모두 알파 = 1), 테두리 영역에서 알파 = 1 (첫 번째 층 알파 = 1, 두 번째 층 알파 = 0).
코드 :
<code>button { /* same base styles */ --full: linear-gradient(red 0 0); -webkit-mask: var(--full) padding-box, var(--full); -webkit-mask-composite: xor; mask: var(--full) padding-box exclude, var(--full); }</code>
세부 사항 : 적색 구배는 간결하게 사용됩니다. 그라디언트는 배경 클립 제한으로 인해 두 층에 사용됩니다. 표준 mask-composite
비표준 버전이 무시와 함께 포함되어 있습니다.
이것은 그라디언트 테두리를 생성하지만 텍스트가 부족합니다. 텍스트 (투명 텍스트 포함)로 제한 된 세 번째 마스크 레이어를 추가하고 이전 결과로 Xoring 텍스트가 다시 추가됩니다. 그러나 이것은 mask-clip
의 비표준 text
값으로 인해 크롬에 따라 다릅니다. @supports
블록은 크로스 브라우저 호환성을 보장합니다 (지원하지 않는 브라우저에서 텍스트 마스킹없이).
<code>button { /* same base styles */ @supports (-webkit-mask-clip: text) { -webkit-text-fill-color: transparent; --full: linear-gradient(red 0 0); -webkit-mask: var(--full) text, var(--full) padding-box, var(--full); -webkit-mask-composite: xor; } }</code>
이는 간단한 접근 방식이지만 비표준 기능에 대한 의존은 브라우저 호환성을 제한합니다. 대안적이고 더 광범위하게 지원되는 방법을 살펴 보겠습니다.
대체 접근법 : 의사 요소 및 경계 이미지 솔루션
여분의 의사 요소 솔루션은 배경을 텍스트 영역에 클리핑하고 절대적으로 배치 된 구배 테두리를 추가하여 마스킹을 피합니다 ::before
국경-이미지 솔루션은 더 간단하지만 border-radius
에는 한계가 있습니다. 이 방법은 크롬 특이 적 솔루션보다 더 나은 크로스 브라우저 호환성을 제공합니다. 이러한 방법에 대한 자세한 내용 및 코드 예제는 원본 기사에 제공됩니다. 원래 기사에 설명 된 블렌딩 솔루션은 또 다른 접근 방식을 제공하지만 배경 상호 작용에 관한 한계가 있습니다. 각 방법에는 원하는 수준의 크로스 브라우저 지원 및 특정 설계 요구 사항에 따라 강점과 약점이 있습니다.
위 내용은 CSS-ing Candy Ghost 버튼의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

라이브 토크 나 수업 중에 대화식 애니메이션을 표시해야한다면 슬라이드와 상호 작용하기가 항상 쉽지 않다는 것을 알 수 있습니다.

Astro를 사용하면 빌드 중에 대부분의 사이트를 생성 할 수 있지만 Fuse.js와 같은 것을 사용하여 검색 기능을 처리 할 수있는 작은 서버 측 코드가 있습니다. 이 데모에서는 퓨즈를 사용하여 개인 "북마크"세트를 검색합니다.

문서가 저장되는 동안 Google 문서에서 볼 수있는 것과 유사한 프로젝트 중 하나에서 알림 메시지를 구현하고 싶었습니다. 다시 말해, a

몇 달 전에 나는 해커 뉴스를 썼고 (하나와 마찬가지로) IF 문을 사용하지 않는 것에 대한 (현재 삭제 된) 기사를 가로 질러 달렸습니다. 이 아이디어를 처음 접한다면 (나처럼

공상 과학 소설의 초기부터 우리는 우리와 대화하는 기계에 대해 환상을 가지고 있습니다. 오늘은 평범합니다. 그럼에도 불구하고 제작 기술

Gutenberg가 핵심으로 풀려 났을 때를 기억합니다. 왜냐하면 나는 그날 WordCamp에 있었기 때문입니다. 지금은 몇 달이 지났으므로 점점 더 많은 것을 상상합니다.

대부분의 웹 애플리케이션의 배후에있는 아이디어는 데이터베이스에서 데이터를 가져 와서 최상의 방법으로 사용자에게 제시하는 것입니다. 우리가 거기에서 데이터를 다룰 때

#039;는 당신이 의미있는 것처럼 보일 수있는 상황에 대한 약간의 단계를 수행하자. 이것에서


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.
