찾다
웹 프론트엔드CSS 튜토리얼웹 구성 요소에 대한 스타일링 옵션을 통해 생각합니다

웹 구성 요소에 대한 스타일링 옵션을 통해 생각합니다

웹 구성 요소에서 스타일을 어디에 넣습니까?

나는 우리가 여기서 그림자 dom을 나에게 사용하고 있다고 가정하고, 그것은 그것이 웹 구성 요소의 큰 추첨 중 하나입니다 : 플랫폼만이 플랫폼 만 할 수있는 독특한 강력한 일입니다. 따라서 이것은 웹 구성 요소의 스타일을 누출되지 않은 방식으로 정의하는 것입니다. 따라서 글로벌 스타일을 유출하는 방법이 적습니다 (매우 흥미 롭지 만 기사에서 나중에 볼 수있는 사용자 정의 속성을 통해 수행 할 수 있습니다).

템플릿 리터럴과 템플릿에 데이터를 잘 뿌릴 수있는 방법으로 인해 JavaScript 내부에 템플릿을 작성하는 경우 JavaScript의 해당 스타일에 액세스해야합니다.

 const 템플릿 =`
   $ {Styles} 
  <div>
    <h2 id="title"> $ {title} </h2>
    $ {content}
  </div>
`;;

그 스타일 변수는 어디에서 왔습니까? 어쩌면 템플릿 문자가 있습니까?

 const 스타일 =`
  :주인 {
    배경 : 흰색;
  }
  H2 {
    글꼴 : 900 1.5REM/1.1- 시스템 -UI, SANS-SERIF;
  }
`;;

나는 그것이 괜찮다고 생각하지만,이 웹 구성 요소를 구축하려는 클래스 어딘가에있는 큰 지저분한 코드 블록을 만듭니다.

또 다른 방법은

 <emplate>
  
    :주인 {
      배경 : 흰색;
    }
    H2 {
      글꼴 : 900 1.5REM/1.1- 시스템 -UI, SANS-SERIF;
    }
  스타일>

  <div>
    <h2> </h2>
    <p> </p>
  </div>
템플릿></emplate>

HTML에서 HTML을 유지하기 때문에 이것으로 호소력을 볼 수 있습니다. 내가 좋아하지 않는 것은 수동 Shadowroot.querySelector ( "#title-hook")를해야한다는 것입니다. InnerHtml = myData.title; 그 템플릿을 살리기 위해 노력하십시오. 편리한 템플릿처럼 느껴지지 않습니다. 나는 또한 당신이 당신의 HTML 어딘가에이 템플릿을 척해야한다는 것을 좋아하지 않습니다. 어디? 나는 몰라. 그냥 거기에 chuck. chuck.

CSS는 JavaScript에서도 옮겨졌지만 하나의 어색한 위치에서 다른 위치로 이동했습니다.

CSS 파일에 CSS를 보관하고 싶다면 다음과 같이 할 수 있습니다.

 <emplate>
  
    @import "/css/components/card.css";
  스타일>

  <div>
    <h2> </h2>
    <p> </p>
  </div>
템플릿></emplate>

(

이제 우리는 추가 HTTP 요청 인 @Import가 있으며 성능 히트로 악명 높습니다. 스티븐 램버트 (Steven Lambert)의 기사에 따르면 반으로 2 초 더 느려졌다 고 밝혔다. 이상적이지 않습니다. 대신 이것을하는 것이 훨씬 낫다고 생각하지 않습니다.

 클래스 mycomponent 확장 htmlelement {
    
  생성자 () {
    감독자();
    this.attachshadow ({모드 : "Open"});

    페치 ( '/css/components/card.css')
      . then (response => response.text ())
      . 그런데 (data => {
        let node = document.createElement ( 'style');
        node.innerhtml = data;
        document.body.appendChild (노드);
      });
  }

  // ...
}

그것이 잠재적으로 불안정 한 웹 시설 인 것처럼 보입니까? 나는 엉덩이에서 내려서 테스트해야한다고 생각합니다.

이제 이것을 다시 파고 들었으므로 :: 부분이 증기 (설명자)를 얻었습니다. 그래서 나는 할 수있다…

 const 템플릿 =`
  <div part="card">
    <h2 id="title"> $ {title} </h2>
    $ {content}
  </div>
`;;

… 그런 다음 글로벌 스타일 시트에 스타일을 작성하여 그 그림자 돔 내부에만 적용됩니다.

 my-card :: part (card) {
  배경 : 검은 색;
  색상 : 흰색;
}

… 브라우저 지원이 적용되었지만 충분하지 않습니까?

이 "부품"선택기는 연결된 정확한 요소 만 터치 할 수 있습니다. 모든 단일 DOM 노드에 부품 이름을 적용한 다음 각 스타일을 완전히 스타일링하여 모든 스타일을 수행해야합니다. 특히 Shadow Dom의 매력은 우리가 느슨한 CSS 선택기를 쓸 수있는이 고립 된 스타일 환경이기 때문에 우리의 H2 {} 스타일이 모든 곳에서 누출 될 것이라고 걱정하지 않기 때문입니다.

기본 CSS 모듈이 일이되면 가장 유용한 일이 될 것 같습니다.

 './styles.css'에서 가져 오는 스타일;

Class Myelement는 htmlelement {
  생성자 () {
    this.attachshadow ({모드 : Open});
    this.shadowroot.adoptedStylesheets = [Styles];
  }
}

그러나 이것이 어떤 종류의 성능 향상인지 확실하지 않습니다. 이것과 @import 사이의 세척 일 것 같습니다. 나는 기본 CSS 모듈의 선명도와 구문을 선호한다고 말해야합니다. JavaScript로 작업 할 때 JavaScript를 작성하는 것이 좋습니다.

구성 가능한 스타일 시트는 여러 구성 요소에서 스타일 시트를 공유하는 데 도움이됩니다. 그러나 CSS 모듈 접근 방식은 스타일 시트가 이미 그 시점에서 변수가 되었기 때문에 그렇게 할 수있는 것처럼 보입니다.

위 내용은 웹 구성 요소에 대한 스타일링 옵션을 통해 생각합니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
두 개의 이미지와 API : 제품을 다시 칠하는 데 필요한 모든 것두 개의 이미지와 API : 제품을 다시 칠하는 데 필요한 모든 것Apr 15, 2025 am 11:27 AM

최근에 제품 이미지의 색상을 동적으로 업데이트하는 솔루션을 찾았습니다. 따라서 제품 중 하나만 사용하여 다른 방식으로 색칠 할 수 있습니다.

주간 플랫폼 뉴스 : 제 3 자 코드, 수동 혼합 콘텐츠, 가장 느린 연결이있는 국가의 영향주간 플랫폼 뉴스 : 제 3 자 코드, 수동 혼합 콘텐츠, 가장 느린 연결이있는 국가의 영향Apr 15, 2025 am 11:19 AM

이번 주에 라운드 업, Lighthouse는 타사 스크립트에 빛을 비추고 불안한 자원이 안전한 사이트에서 차단되고 많은 국가 연결 속도가 차단됩니다.

직접 비자 스크립트 기반 분석을 호스팅하는 옵션직접 비자 스크립트 기반 분석을 호스팅하는 옵션Apr 15, 2025 am 11:09 AM

사이트에서 방문자 및 사용 데이터를 추적하는 데 도움이되는 분석 플랫폼이 많이 있습니다. 아마도 널리 사용되는 Google 웹 로그 분석

그것은 모두 헤드에있는 모든 것 : React Helmet과 함께 React 전원 사이트의 문서 헤드 관리그것은 모두 헤드에있는 모든 것 : React Helmet과 함께 React 전원 사이트의 문서 헤드 관리Apr 15, 2025 am 11:01 AM

문서 헤드는 웹 사이트에서 가장 화려한 부분이 아닐 수도 있지만 웹 사이트의 성공에 중요합니다.

JavaScript의 Super () 란 무엇입니까?JavaScript의 Super () 란 무엇입니까?Apr 15, 2025 am 10:59 AM

Super ()?를 호출하는 JavaScript를 볼 때 어떤 일이 발생 하는가. 아동 클래스에서는 Super ()를 사용하여 부모의 생성자와 Super를 호출합니다. 그것의 접근

다양한 유형의 기본 JavaScript 팝업 비교다양한 유형의 기본 JavaScript 팝업 비교Apr 15, 2025 am 10:48 AM

JavaScript에는 사용자 상호 작용을위한 특수 UI를 표시하는 다양한 내장 팝업 API가 있습니다. 뛰어나게:

액세스 가능한 웹 사이트를 구축하기가 어려운 이유는 무엇입니까?액세스 가능한 웹 사이트를 구축하기가 어려운 이유는 무엇입니까?Apr 15, 2025 am 10:45 AM

나는 다른 날에 많은 회사들이 액세스 가능한 웹 사이트를 만드는 데 어려움을 겪고있는 이유에 대해 다른 프론트 엔드 사람들과 대화를 나누고있었습니다. 액세스 가능한 웹 사이트가 왜 그렇게 어려운가

'숨겨진'속성은 눈에 띄게 약합니다'숨겨진'속성은 눈에 띄게 약합니다Apr 15, 2025 am 10:43 AM

당신이해야 할 일을 정확하게 수행하는 HTML 속성이 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

mPDF

mPDF

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

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기