How to set image path with StyleBundle:
In this article, you will learn how to resolve absolute path in css file.
We learned in the MVC tutorial that Include method of Bundle class accepts filename with virtual path.
data:image/s3,"s3://crabby-images/240da/240dabdf508eb3cde6c54dea60758475a3bb1090" alt=""
If you open browser debugger, you can see that css file has been loaded with Status 200.
data:image/s3,"s3://crabby-images/e8960/e8960a31de952a83761db6a5b9f5b108128d2fd0" alt=""
However, if site.css contains images with absolute path then images will not load. For example, our following site.css contains footer style as shown below.
footer
{
background:url(../images/border_btm.png) top repeat-x;
padding:15px;
color:#618eac;
margin-top:15px;
}
The above footer style references the background image, which is in the separate images folder.
data:image/s3,"s3://crabby-images/625a1/625a101e6ac668bc904ea50c40860e4d38d0440c" alt=""
However, browser will give 404 error because it could not find image file.
data:image/s3,"s3://crabby-images/73b6b/73b6b6b770c3328d9d5d072cbe56d6f96e279a9d" alt=""
The browser will consider virtual path for any path given in the css file. It will try to load image from h
data:image/s3,"s3://crabby-images/a0fdb/a0fdbe783527ac57367f51d0e871ea56c5170722" alt=""
Solution:
If you use absolute path in your css for images then you can specify transformation class CssRewriteUrlTransform.
CssRewriteUrlTransform class rewrites urls to absolute path.
bundles.Add(new StyleBundle("~/bundles/css").Include(
"~/Content/css/site.css",
new CssRewriteUrlTransform()
));
Now, image path in the css file will be transform to absolute path.
data:image/s3,"s3://crabby-images/ee5a9/ee5a9f1db0ef4bd68fbf6be3fefd9b619c88f0f2" alt=""
As you can see in the above figure, image is loaded using absolute path from root folder.