"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 변수를 사용하여 LESS에서 속성 이름을 동적으로 생성하려면 어떻게 해야 합니까?

변수를 사용하여 LESS에서 속성 이름을 동적으로 생성하려면 어떻게 해야 합니까?

2024년 12월 21일에 게시됨
검색:864

How can I use variables to dynamically create property names in LESS?

LESS에서 속성 이름에 변수 사용(동적 속성/속성 이름 보간)

LESS는 주제에 대한 일부 논의에도 불구하고 현재 동적으로 삽입된 속성을 지원하지 않습니다. 스택 오버플로.

해결 방법 #1: 동적으로 생성된 속성을 속성 값에 삽입

이것은 해결 방법은 동적으로 생성된 속성을 하드 코딩된 속성 값에 삽입합니다.

.vendors(@property, @value, @pre: ect) {
  -inj:~"@{pre}; -webkit-@{property}: @{value}; -moz-@{property}: @{value}; -ms-@{property}: @{value}; -o-@{property}: @{value}; @{property}: @{value}";
}

해결 방법 #2: 동적으로 생성된 속성을 다음 클래스의 이름에 삽입(LESS

이 해결 방법은 다음 클래스 또는 규칙 세트를 구성합니다. 공급업체를 포함하고 다음 클래스인

.vendors(@property, @value, @rest:"") {
  @inject:~"@{rest} -webkit-@{property}: @{value}; -moz-@{property}: @{value}; -ms-@{property}: @{value}; -o-@{property}: @{value}; @{property}: @{value};";
}

.test(@nextclass){
  .vendors(transform, "matrix(2,0,0,2,20,20)");
  .vendors(transform-origin,"10px 10px", @inject);
  (~"{@{inject}} .@{nextclass}"){/*next class properties*/};
}

해결 방법 #3: 동적으로 생성된 속성을 다음 클래스의 이름에 삽입(LESS 1.4.0)

이 버전은 LESS 1.4의 제한 사항을 극복하기 위해 재귀를 사용합니다. .0:

@nl: `"\n\t"`;

.multi(@props,@vals,@i,@inj) {
  @property: extract(@props, 1);
  @value: extract(@vals, 1);
  @inject:~"@{inj}@{nl}-webkit-@{property}: @{value};@{nl}-moz-@{property}: @{value};@{nl}-ms-@{property}: @{value};@{nl}-o-@{property}: @{value};@{nl}@{property}: @{value};";
}

.multi(@props,@vals,@i,@inj:"") when (@i > 0) {
  @property: extract(@props, @i);
  @value: extract(@vals, @i);
  @injnext:~"@{inj}@{nl}-webkit-@{property}: @{value};@{nl}-moz-@{property}: @{value};@{nl}-ms-@{property}: @{value};@{nl}-o-@{property}: @{value};@{nl}@{property}: @{value};";
  .multi(@props,@vals,(@i - 1),@injnext);
}

LESS 버전 1.6 이상에서는 속성 이름 보간이 기본적으로 구현되므로 해결 방법이 필요하지 않습니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3