質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

2回答

729閲覧

valueをCSSに使うことはできないのでしょうか?

ikkouenosenpai

総合スコア16

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2019/02/17 13:07

value(またはデータ属性)をbackground-colorに用いる方法はあるでしょうか?

まず、これはできますよね?

css

1content: attr(value); 2content: attr(data-type);

では、こちらはできないのでしょうか?

css

1background-color: attr(value); 2background-color: attr(data-type);

もしできないとすると、どのような理屈でできないのでしょうか?

教えてください。宜しくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2019/02/17 13:29

どういうhtmlでどういう結果を得たいのか具体的に書かれたほうが良いかと思います。 そうでないと「リファレンス読んで試してみれば良いのでは」くらいの回答しかのぞめないと思います。 (もしできないという結論であっても理屈も何も仕様でしかないわけですし)
ikedas

2019/02/17 14:42

前のほうの例は、完全なCSSのコードになっていないとおもうんですが
ikkouenosenpai

2019/02/17 20:15

みなさんご指摘ありがとうございます。
m.ts10806

2019/02/17 21:07

質問編集して追記いただければ良いのですが…
guest

回答2

0

ベストアンサー

CSS2 で、attr関数はcontentプロパティのみが値として使うことの出来る関数とされていました。

Value: normal | none | [ <string> | <uri> | <counter> | attr(<identifier>) | open-quote | close-quote | no-open-quote | no-close-quote ]+ | inherit

参考: Cascading Style Sheets Level 2 Revision 2 (CSS 2.2) Specification - 12.2 The 'content' property

各ブラウザは、この仕様の通りにattr関数を実装しました。そして現在、 CSS Values and Units Module Level 3 が勧告候補となり、この仕様の中で、attr関数はすべての CSS プロパティで使用可能になりました。

The attr() function is allowed as a component value in properties applied to an element or pseudo-element.

参考: CSS Values and Units Module Level 3 - §8.2. Attribute References: attr()

このことから、すべての CSS プロパティでattr関数が使えるようになったのは、仕様上では CSS3 からとわかります。つまり私たちは、attr関数がすべてのプロパティで使えるようになることを、 10 年近く待っていることになります。なぜこれほどの長い期間、attr関数がブラウザに実装されないのか、私には推測することしか出来ませんが、以下のような事情が考えられます。

  • この機能よりも優先して実装すべき機能が数多く存在する
  • 未解決のバグが存在する

いずれにせよ、今は使えない機能なので、少しでも早く実装されることを願い、待つしかありません。代替としては、以下の 2 つの方法が考えられます。

属性セレクタを使う

属性セレクタを使い、各値での CSS プロパティを記述しておくことで、attr関数と同じようなことができますが、想定外の値への対応が難しく、 CSS の記述量が多くなるため、使えるものではないと思います(動作確認用リンク)。

HTML

1<div data-width="a"></div>

CSS

1div { 2 height: 1.5em; 3} 4 5div[data-width="a"] { 6 background-color: red; 7 width: 2em; 8} 9 10div[data-width="b"] { 11 background-color: green; 12 width: 6em; 13} 14 15div[data-width="c"] { 16 background-color: blue; 17 width: 1em; 18}

JavaScript を使う

こちらについては、既に Polyfill を作ってくれた人がいるようです。ただし、完璧に仕様のとおりに動作するかは保障できません。

投稿2019/02/17 16:29

編集2019/02/17 16:47
s8_chu

総合スコア14731

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kei344

2019/02/17 16:32

もしかして回答をエディタで作ってコピー&ペースしていませんか?teratail のバグで記述内容が表示されないというものが以前有ったので、ペースト後に何文字か記入してみてください。
s8_chu

2019/02/17 16:40

ご指摘ありがとうございます。 ページの読み込みが完了していない状態で投稿すると、回答が空白になってしまうのでしたね。 回答を修正しました。
ikkouenosenpai

2019/02/17 20:16

ご回答どうもありがとうございます。とてもためになる内容でした。
guest

0

ブラウザが対応していないので、まだ無理です。

【attr() - CSS: カスケーディングスタイルシート | MDN】
https://developer.mozilla.org/ja/docs/Web/CSS/attr

メモ: attr() 関数はどの CSS プロパティでも使用することができますが、 content 以外のプロパティでの対応は実験的であり、型や単位の引数の対応はまちまちです。

【Can I use... Support tables for HTML5, CSS3, etc】
https://caniuse.com/#feat=css3-attr

投稿2019/02/17 16:28

kei344

総合スコア69407

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ikkouenosenpai

2019/02/17 20:14

ソースまでありがとうございます。納得できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問