ホームページ >ウェブフロントエンド >CSSチュートリアル >変数を使用して LESS でプロパティ名を動的に作成するにはどうすればよいですか?

変数を使用して LESS でプロパティ名を動的に作成するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-11-14 21:59:02909ブラウズ

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 以降では、プロパティ名の補間がネイティブに実装されるため、回避策はありません。必要です。

以上が変数を使用して LESS でプロパティ名を動的に作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。