docs.rodeo

MDN Web Docs mirror

url()

{{CSSRef}} 

The url() CSS function is used to include a file. The parameter is an absolute URL, a relative URL, a blob URL, or a data URL. The url() function can be passed as a parameter of another CSS function, like the {{cssxref("attr")}}  function. Depending on the property for which it is a value, the resource sought can be an image, font, or a stylesheet. The url() functional notation is the value for the <url> data type.

[!NOTE] There is a difference between a {{Glossary("URI")}}  and a {{Glossary("URL")}} . A URI identifies a resource. A URL is a type of URI, and describes the location of a resource. A URI can be either a URL or a name ({{Glossary("URN")}} ) of a resource.

In CSS Level 1, the url() functional notation described only true URLs. In CSS Level 2, the definition of url() was extended to describe any URI, whether a URL or a URN. Confusingly, this meant that url() could be used to create a <uri> CSS data type. This change was not only awkward but, debatably, unnecessary, since URNs are almost never used in actual CSS. To alleviate the confusion, CSS Level 3 returned to the narrower, initial definition. Now, url() denotes only true <url>s.

/* Basic usage */
url("https://example.com/images/myImg.jpg");
url('https://example.com/images/myImg.jpg');
url(https://example.com/images/myImg.jpg);
url("…");
url(myImg.jpg);
url(#IDofSVGpath);

/* associated properties */
background-image: url("star.gif");
list-style-image: url('../images/bullet.jpg');
content: url("my-icon.jpg");
cursor: url(my-cursor.cur);
border-image-source: url(/media/diamonds.png);
src: url('fantastic-font.woff');
offset-path: url(#path);
mask-image: url("masks.svg#mask1");

/* Properties with fallbacks */
cursor: url(pointer.cur), pointer;

/* Associated short-hand properties */
background: url('star.gif') bottom right repeat-x blue;
border-image: url("/media/diamonds.png") 30 fill / 30px / 30px space;

/* As a parameter in another CSS function */
background-image: cross-fade(20% url(first.png), url(second.png));
mask-image: image(url(mask.png), skyblue, linear-gradient(rgb(0 0 0 / 100%), transparent));

/* as part of a non-shorthand multiple value */
content: url(star.svg) url(star.svg) url(star.svg) url(star.svg) url(star.svg);

/* at-rules */
@document url("https://www.example.com/") { /* … */ }
@import url("https://www.example.com/style.css");
@namespace url(http://www.w3.org/1999/xhtml);

Relative URLs, if used, are relative to the URL of the stylesheet (not to the URL of the web page).

The url() function can be included as a value for {{cssxref('background')}} , {{cssxref('background-image')}} , {{cssxref('border')}} , {{cssxref('border-image')}} , {{cssxref('border-image-source')}} , {{cssxref('content')}} , {{cssxref('cursor')}} , {{cssxref('filter')}} , {{cssxref('list-style')}} , {{cssxref('list-style-image')}} , {{cssxref('mask')}} , {{cssxref('mask-image')}} , {{cssxref('offset-path')}} , {{cssxref('clip-path')}} , src as part of a @font-face block, and @counter-style/symbol

Syntax

Values

Formal syntax

{{CSSSyntax("url")}} 

Examples

As the background property value

body {
  background: url("https://mdn.github.io/shared-assets/images/examples/leopard.jpg")
    #00d no-repeat fixed;
}

{{EmbedLiveSample("As the background property value", "100%", "200")}} 

For setting an image as a list bullet

<ul>
  <li>one</li>
  <li>two</li>
  <li>there</li>
</ul>
ul {
  font-size: 3rem;
  margin: 0;
}
ul {
  list-style: outside
    url("https://mdn.github.io/shared-assets/images/examples/firefox-logo.svg");
}

{{EmbedLiveSample("For setting an image as a list bullet", "100%", "200")}} 

Usage in the content property

HTML

<ul>
  <li>One</li>
  <li>Two</li>
  <li>Three</li>
</ul>

CSS

li::after {
  content: " - "
    url("https://mdn.github.io/shared-assets/images/examples/star-white_16x16.png");
}

Result

{{EmbedLiveSample("Usage_in_the_content_property", "100%", "110")}} 

Using a data URL

CSS

body {
  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_URL", "100%", 100)}} 

Usage in filters

When a URL is used as a path for a filter, the URL must be one of the following:

  1. The path to an SVG file with the ID of the filter appended.
  2. the ID of the filter, if the SVG already exists on the page.
.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 */
}

Specifications

{{Specifications}} 

Browser compatibility

{{Compat}} 

See also

In this article

View on MDN