【发布时间】:2014-02-21 11:04:17
【问题描述】:
我有一个基于 ASP.NET MVC4 的 Web 应用程序,其中我使用包含三个语言标志(图像)的布局。这些标志在整个站点中都是可见的。现在我想使用这些图像进行语言选择。为了以特定语言显示任何页面,我只需向当前 URL 添加一个参数并加载它,然后我的控制器对其进行评估并在模型中设置正确的语言(或者在有请求中未指定语言)。
这是一个例子:
未指定语言:
http://example.com?StationId=12
指定语言:
http://example.com?StationId=12&lang=1033
我的问题是:如何在我的布局中形成一个围绕语言标志图像的链接,并始终指向当前加载的 URL,所有参数 加上一个新参数 &lang=1033 分别@ 987654324@万一只有语言参数?
换句话说:如何使用所有参数创建指向同一页面的链接,并简单地将路由值添加到 URL?
更新:这里有一个详细的例子
在我的_Layout.cshtml 我有:
@{
var u_eng = new RouteValueDictionary(Url.RequestContext.RouteData.Values);
var u_deu = new RouteValueDictionary(Url.RequestContext.RouteData.Values);
var u_por = new RouteValueDictionary(Url.RequestContext.RouteData.Values);
u_eng.Add("lang", "1033");
u_deu.Add("lang", "1031");
u_por.Add("lang", "1046");
}
.
.
.
<li>
<a href="@Url.RouteUrl(u_por)" class="Flag BR">BR</a>
</li>
<li>
<a href="@Url.RouteUrl(u_eng)" class="Flag US">US</a>
</li>
<li>
<a href="@Url.RouteUrl(u_deu)" class="Flag DE">DE</a>
</li>
现在,当我运行网站时,起始页上的链接工作正常,它们指向当前页面并将 lang=xy 参数添加到相应的 URL。
但是当我转到另一个使用相同布局文件并使用参数的页面时,链接无法正确构建:假设我转到由该 URL 定义的子页面:
http://localhost:1234/Stations?position=up
页面本身会正确显示。但是当我悬停或点击语言链接时,它们指向:
http://localhost:1234/Stations?lang=1031 而不是
http://localhost:1234/Stations?position=up&lang=1031
如您所见,所有现有参数都被省略了。
【问题讨论】:
标签: c# asp.net-mvc-4 razor hyperlink routevalues