我有一个基于 ASP.NET MVC4 的 Web 应用程序,其中我使用包含三个语言标志(图像)的布局。这些标志在整个站点中都是可见的。现在我想使用这些图像进行语言选择。为了以特定语言显示任何页面,我只需向当前 URL 添加一个参数并加载它,然后我的控制器对其进行评估并在模型中设置正确的语言(或者在有请求中未指定语言)。
这是一个例子:
未指定语言:
http://example.com?StationId=12
指定语言:
http://example.com?StationId=12&lang=1033
我的问题是:如果只有语言参数,如何在我的布局中形成一个围绕语言标志图像的链接,并始终指向当前加载的带有所有参数的 URL 加上一个新参数?&lang=1033
?lang=1033
换句话说:如何使用所有参数创建指向同一页面的链接,并简单地将路由值添加到 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
如您所见,任何现有参数都被省略了。