--- title: url() slug: Web/CSS/url() tags: - CSS - CSS Function - Function - Layout - Reference - Web - url() browser-compat: css.types.url translation_of: Web/CSS/url() ---
url()
は CSS 関数で、ファイルを含めるために使用します。引数は絶対 URL、相対 URL、 データ URI の何れかです url()
関数は {{cssxref('attr()')}} 関数のように、他の CSS 関数に引数として渡すことができます。値を使用するプロパティに応じて、求められるリソースは画像、フォント、スタイルシートの何れかになります。 url() 関数表記は the <url> データ型の値になります。
URI か URL か? {{Glossary("URI")}} と {{Glossary("URL")}} との間には違いがあります。 URI は単純にリソースを識別します。 URL は URI の一種で、リソースの場所を記述します。 URI はリソースの URL または名前 ({{Glossary("URN")}}) であることがあります。
CSS Level 1 では、 url()
関数記法は真に URL のみを記述していました。 CSS Level 2 では、 url()
の定義はあらゆる URI、 URL または URN のどちらかを記述するように拡張されました。ややこしいことに、これは url()
を CSS の <uri>
データ型の生成のために使用することができることを意味していました。この変更は紛らわしいばかりでなく、議論になりやすく、 URN が実際の CSS で使用されることはほぼあり得ないため不必要でした。混乱を軽減するために、 CSS Level 3 ではより狭い初めの定義まで戻りました。現在では、 url()
は真に <url>
のみを記述します。
/* 単純な使い方 */ url(https://example.com/images/myImg.jpg); url(…); url(myFont.woff); url(#IDofSVGpath); /* 関連するプロパティ */ background-image: url("https://mdn.mozillademos.org/files/16761/star.gif"); list-style-image: url('../images/bullet.jpg'); content: url("pdficon.jpg"); cursor: url(mycursor.cur); border-image-source: url(/media/diamonds.png); src: url('fantasticfont.woff'); offset-path: url(#path); mask-image: url("masks.svg#mask1"); /* 代替付きのプロパティ */ cursor: url(pointer.cur), pointer; /* 関連する一括指定プロパティ */ background: url('https://mdn.mozillademos.org/files/16761/star.gif') bottom right repeat-x blue; border-image: url("/media/diamonds.png") 30 fill / 30px / 30px space; /* 他の CSS 関数の引数として */ background-image: cross-fade(20% url(first.png), url(second.png)); mask-image: image(url(mask.png), skyblue, linear-gradient(rgba(0, 0, 0, 1.0), transparent); /* 一括指定ではない複数の値の一部として */ content: url(star.svg) url(star.svg) url(star.svg) url(star.svg) url(star.svg); /* @-規則 */ @document url("https://www.example.com/") { ... } {{Experimental_Inline}} @import url("https://www.example.com/style.css"); @namespace url(http://www.w3.org/1999/xhtml);
相対 URL が使用された場合は、 (ウェブページの URL からではなく) スタイルシートの URL からの相対となります。
url()
関数は {{cssxref('background')}}, {{cssxref('background-image')}}, {{cssxref('list-style')}}, {{cssxref('list-style-image')}}, {{cssxref('content')}}, {{cssxref('cursor')}}, {{cssxref('border')}}, {{cssxref('border-image')}}, {{cssxref('border-image-source')}}, {{cssxref('mask')}}, {{cssxref('mask-image')}}, @font-face ブロック内での src, @counter-style/symbol 値として使用することができます。
<string>
<css_property>: url("https://example.com/image.png") <css_property>: url('https://example.com/image.png') <css_property>: url(https://example.com/image.png)
URL を引用符なしで書く場合は、 URL に含まれる括弧、ホワイトスペース文字、単一引用符 ('
)、二重引用符 ("
) の前にバックスラッシュを (\
) を使用してください。
circle
, ellipse
, line
, path
, polygon
, polyline
, rect
-- パスとして図形の形状を使用します。<url-modifier>
{{Experimental_Inline}}url()
関数は、 URL 文字列の意味を変更する修飾子、識別子、関数記法を指定することに対応するかもしれません。これはまだ対応されておらず、仕様書では完全には定義されていません。url( <string> <url-modifier>* )
.topbanner { background: url("topbanner.png") #00D no-repeat fixed; }
ul { list-style: square url(http://www.example.com/redball.png); }
<ul> <li>Item 1</li> <li>Item 2</li> <li>Item 3</li> </ul>
li::after { content: ' - ' url(https://mdn.mozillademos.org/files/16761/star.gif); }
{{EmbedLiveSample("Usage_in_the_content_property", "100%", 110)}}
<div class="background"></div>
.background { height: 100vh; }
.background { background: yellow; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='45'%3E%3Cpath d='M10 10h60' stroke='%2300F' stroke-width='5'/%3E%3Cpath d='M10 20h60' stroke='%230F0' stroke-width='5'/%3E%3Cpath d='M10 30h60' stroke='red' stroke-width='5'/%3E%3C/svg%3E"); }
{{EmbedLiveSample("Using_a_data-uri", "100%", 50)}}
URL がフィルターへのパスとして使用される場合、 URL は以下のどちらかでなければなりません。
.blur { filter: url(my-file.svg#svg-blur); /* the URL of an SVG file used as a filter */ } .inline-blur { filter: url(#svg-blur); /* the ID of an SVG that is embedded in the HTML page */ }
仕様書 | 状態 | 備考 |
---|---|---|
{{SpecName('CSS4 Values', '#urls', 'url()')}} | {{Spec2('CSS4 Values')}} | |
{{SpecName('CSS3 Values', '#urls', 'url()')}} | {{Spec2('CSS3 Values')}} | CSS 第2水準 (第1稿) から重要な変更なし |
{{Specname('CSS2.1', 'syndata.html#uri', 'uri()')}} | {{Spec2('CSS2.1')}} | CSS 第1水準から重要な変更なし |
{{SpecName('CSS1', '#url', 'url()')}} | {{Spec2('CSS1')}} | 初回定義 |