「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > 変数を使用して LESS でプロパティ名を動的に作成するにはどうすればよいですか?

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

2024 年 12 月 21 日に公開
ブラウズ:862

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

LESS でのプロパティ名での変数の使用 (動的プロパティ / プロパティ名の補間)

LESS は現在、動的に挿入されたプロパティをサポートしていません。スタック オーバーフロー。

回避策 1: 動的に生成されたプロパティをプロパティに挿入するValue

この回避策は、動的に作成されたプロパティをハードコーディングされたプロパティ値に挿入します:

.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