我之前尝试过以不同的方式提出这个问题,但没有被理解,所以我将尝试另一种方式:
我有一个 MVC 3 应用程序,像往常一样在 Views 目录中有视图。但是,由于各种原因,我需要每个视图的图像与视图本身位于同一文件夹中,即在我的情况下,例如 Views/Manuals/en-US/name
这是我使用的路线:
routes.MapRoute(
"Parameter",
"{controller}/{action}/{lang}/{prod}",
new { controller = "Manuals", action = "Product", lang = "en-US", prod = "name" }
);
现在,如前所述,我需要此视图的图像位于同一文件夹中,以便图像路径可以简单地为“ATEXSymbol.svg”。
当我只有这条路线,并为图像使用这样的简单相对路径时,我得到的是这样的错误:
未找到视图“da-DK/ATEXSymbol.svg”或其主视图,或者没有视图引擎支持搜索到的位置。搜索了以下位置:~/Views/Manuals/da-DK/ATEXSymbol.svg.aspx ~/Views/Manuals/da-DK/ATEXSymbol.svg.ascx ~/Views/Shared/da-DK/ATEXSymbol.svg。 aspx ~/Views/Shared/da-DK/ATEXSymbol.svg.ascx ~/Views/Manuals/da-DK/ATEXSymbol.svg.cshtml ~/Views/Manuals/da-DK/ATEXSymbol.svg.vbhtml ~/Views/ Shared/da-DK/ATEXSymbol.svg.cshtml ~/Views/Shared/da-DK/ATEXSymbol.svg.vbhtml
所以基本上,它在正确的语言文件夹中寻找图像,但没有产品名称文件夹部分,并且附加了许多视图扩展名之一。我知道 MVC 并不真的希望在同一个文件夹中使用这个相对路径,但我几乎别无选择。我需要将图像放在同一个文件夹中,以防我无法控制。
那么我该如何实现呢?
编辑:
其实上面我有点误会了,说路径的产品名称部分丢失了,当然不是。路径的那部分是视图本身的名称。所以基本上我通过 src 属性中的简单相对路径(只是图像文件的名称)获得的路径为图像创建了正确的路径。唯一的问题是添加了视图文件扩展名......
有谁知道如何解决这个问题?
编辑2:
顺便说一句,我本可以使用 Url.Content,但由于某种原因,它也不起作用。如果我使用这个:
<embed type="image/svg+xml" src="@Url.Content("~/Content/images/da-DK/3153/CheckRotation.svg")"></embed>
...它工作...但是如果我使用它(同样的东西,但在 Views 文件夹中的图像)...
<embed type="image/svg+xml" src="@Url.Content("~/Views/Manuals/da-DK/CheckRotation.svg")"></embed>
......它不起作用。如果我在 web 检查器中检查后一个示例中的路径,它看起来像正确的路径 (localhost:49864/Views/Manuals/da-DK/CheckRotation.svg),但显示找不到它的消息。
编辑 3:
Thinking Sites 的回答给了我一个解决方案,我只需要稍微修改一下,因为我需要为视图本身建议的路线。所以我添加了这条路线:
routes.MapRoute(
"Image",
"{controller}/{action}/{lang}/{prod}",
new { controller = "Manuals", action = "Image", lang = "en-US", prod = "name" }
);
我对路径做了一些调整(如建议的那样),因为 prod 现在实际上带有整个文件名,包括扩展名:
public ActionResult Image(string lang, string prod)
{
var root = Server.MapPath("~/Views/Manuals/");
var filepath = Path.Combine(root, lang, prod); // whatever creates your path here.
return File(filepath, "image/svg+xml");
}
然后在视图中我可以有这样的路径:
<embed type="image/svg+xml" src="@Url.Content("/Manuals/Image/da-DK/CheckRotation.svg")"></embed>