ABP Web开发入门-去掉多语言菜单项

栏目: 后端 · 前端 · 发布时间: 6年前

通过ABP创建工程后,发现导航栏右侧有语言切换选项。但项目刚启动时只需要一种语言,因此需要去掉。

通过浏览器的F12可以发现多语言的id类似navbar-right , 全局搜索后就看到了多语言菜单项实在Views/Shared/_TopBar.cshtml中实现的。

<ul class="nav navbar-nav navbar-right">

@Html.Action("LanguageSelection", "Layout")

</ul>

上面用到Html.Action, msdn如下:

public static MvcHtmlString Action(

this HtmlHelper htmlHelper,

string actionName,

string controllerName,

Object routeValues

)

可以看出是调用了Controllsers/LayoutController类里的LanguageSelection方法。 其实现如下:

[ChildActionOnly]

public PartialViewResult LanguageSelection()

{

var model = new LanguageSelectionViewModel

{

CurrentLanguage = _languageManager.CurrentLanguage,

Languages = _languageManager.GetLanguages()

};

return PartialView("_LanguageSelection", model);

}

msdn如下:

protected internal virtual PartialViewResult PartialView(

string viewName,

object model

)

PartialView方法返回了一个PartialViewResult实例, 这个从ViewResultBase继承的类就是提供model给view,然后呈现ui给用户。也就是把Views/Layout/_LanguageSelection.cshtml 和 vm数据关联在一起来呈现UI。

从ViewResultBase继承下来的有2个类, PartialViewResult和ViewResult,都是为了呈现UI。

当然ViewResultBase是从ActionResult继承下来,都是在controller的action方法中使用的, 只不过有些ActionResult为了呈现UI,有些为了呈现文件,有些为了呈现json字符串等等。

ABP Web开发入门-去掉多语言菜单项

_LanguageSelection.cshtml的代码如下:

@model UIH.NIS.Web.Models.Layout.LanguageSelectionViewModel

<li class="dropdown">

<a href="#" class="dropdown-toggle" data-toggle="dropdown">

<i class="@Model.CurrentLanguage.Icon"></i>

<span>@Model.CurrentLanguage.DisplayName</span>

<b class="caret"></b>

</a>

<ul class="dropdown-menu">

@foreach (var language in Model.Languages)

{

if (language.Name != Model.CurrentLanguage.Name)

{

<li><a href="@Url.Action("ChangeCulture", "AbpLocalization")?cultureName=@(language.Name)&returnUrl=@(Request.Url)"><i class="@language.Icon"></i> @language.DisplayName</a></li>

}

}

</ul>

</li>

可以看到它也限定了它的model类型为LanguageSelectionViewModel, code(Models/Layout/LanguageSelectionViewModel)如下:

public class LanguageSelectionViewModel

{

public LanguageInfo CurrentLanguage { get; set; }

public IReadOnlyList<LanguageInfo> Languages { get; set; }

}

@foreach 是Asp.Net Razor的语法,@关键字用来切入C#遇到在asp页面中, 具体可以看看 w3schools

至此, ABP的多语言实现基本理清, 如果要删除多语言菜单项也就很简单,可以在_TopBar.cshtml中删除html.action呈现partialView的代码。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

设计之下

设计之下

搜狐新闻客户端UED团队 / 电子工业出版社 / 2014-1-1 / CNY 69.00

形而上者谓之道,形而下者谓之器。匠者,器也。处身平凡的匠人不断追求向上的设计之道。本书没有华丽的辞藻和长篇大论的理论,作者是搜狐一线的设计团队,写作过程中他们尽力还原真实的工作场景,并总结出了一些实用的经验和方法。 《设计之下》共三部分,全面讲解了用户体验设计的流程和方法。第一部分为“交互设计”,阐述了从项目启动、解析需求到原型设计的过程,并且总结了交互设计的要点:大局观、操作流程简捷、形式......一起来看看 《设计之下》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

随机密码生成器
随机密码生成器

多种字符组合密码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器