对于一个需要支持多语言的Web应用,一个很常见的使用方式就是通过请求地址来控制界面呈现所基于的语言文化,比如我们在表示请求地址的URL中将上语言文化代码(比如en或者en-US)来指导服务器应该采用怎样的语言来显示界面的内容。对于一个ASP.NET MVC应用来说,我们很容易通过URL路由来实现这样一个功能。
在具体介绍实现之前,我们通过一个简单的例子谈谈最终实现的效果。在通过ASP.NET MVC项目模板创建的空Web应用中,我们创建了如下一个HomeController,默认的Action方法Index用于呈现一个登录View。作为Model的LoginInfo类包含UserName和Password两个属性,分别表示登录输入的用户名和密码。需要注意的是,在两个属性上应用了DisplayAttribute并通过资源的方式指定了显示名称以实现对多语言的支持。
1: public class HomeController : Controller 2: { 3: public ActionResult Index() 4: { 5: return View(new LoginInfo()); 6: } 7: } 8: 9: public class LoginInfo 10: { 11: [Display(Name ="UserName", ResourceType = typeof(Resources))] 12: public string UserName { get; set; } 13: 14: [Display(Name="Password", ResourceType = typeof(Resources))] 15: [DataType(DataType.Password)] 16: public string Password { get; set; } 17: }
如下所示的Action方法Index对应的View的定义,这是一个基于LogInfo的强类型View。
1: @model MvcApp.Models.LoginInfo 2: @using (Html.BeginForm()) 3: { 4: @Html.EditorForModel() 5: <input type="submit" value="@MvcApp.Properties.Resources.Login" /> 6: <input type="button" value="@MvcApp.Properties.Resources.Cancel" /> 7: }
在Global.asax中,我们修改了默认添加的URL路由注册代码,使请求URL中包含相应的语言文化信息({culture})。
1: public class MvcApplication : System.Web.HttpApplication 2: { 3: //其他成员 4: public static void RegisterRoutes(RouteCollection routes) 5: { 6: //其他操作 7: routes.MapRoute( 8: name: "Default", 9: url: "{culture}/{controller}/{action}/{id}", 10: defaults: new { culture="en", controller = "Home", action = "Index", id = UrlParameter.Optional } 11: ); 12: } 13: }
我们直接运行该程序,并在请求地址中指定不同的Culture(en和zh),界面呈现基于的语言正是我们期望的。
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索应用
, 语言
, 路由
, public
, 多语言对应
, password
, 一个
mvc默认路由
,以便于您获取更多的相关知识。