表的本地化是Web环境中非常重要且紧迫的一环。毕竟,你的 站可以由来自不同国家的人访问。那么具体应该如何实现呢?
表的本地化是Web环境中非常重要且紧迫的一环。毕竟,你的 站可以由来自不同国家的人访问。幸运的是,FastReport.Net具有很多不同语言的本地化,我们可以使用它。
让我们看看如何在示例MVC应用程序中执行此操作。
首先,我们将FastReports库连接到项目:
- FastReport;
- FastReport.Web。
由于我将在 站的主页上发布 表,那么用于处理 表对象的代目将加载到HomeController中,即在Index方法中:
public ActionResult Index(string language) { WebReport webReport = new WebReport(); //create instance of WebReport object. webReport.Width = Unit.Percentage(100); //Set report width webReport.Height = Unit.Percentage(100); //Set report heigh string report_path = "J:\Program Files (x86)\FastReports\FastReport.Net\Demos\Reports\"; //Set reports path System.Data.DataSet dataSet = new System.Data.DataSet(); //create data set dataSet.ReadXml(report_path + "nwind.xml"); //Load xml database into dataset webReport.Report.RegisterData(dataSet, "NorthWind"); //register data source in the report webReport.Report.Load(report_path + "Simple Interactive.frx"); //load a report into WebReport object if (language == "ru") //check the language { webReport.DesignerLocale = "ru"; webReport.LocalizationFile = "~/Localization/Russian.frl"; } else { webReport.DesignerLocale = "en"; } webReport.DesignReport = true; //Enable report designer ViewBag.WebReport = webReport; //pass the report to View return View(); }
在第一行中,我们创建了一个WebReport对象的实例。接下来,将web 表的宽度和高度设置为100%。
在变量report_path
中写入 表文件夹的路径。创建一个数据集并将xml数据库加载到其中。之后,我们在 表对象中注册数据源。
现在将 表加载到WebReport对象中。我们检查参数“语言”的值。如果它等于“ru”,那么我们找到设计器,并将web 表本地化设为俄语。否则,将会本地化为英语。
DesignReport属性包括一个在线 表设计器。也就是说,我们在上面下载的 表将立即在设计器中打开。它仍然是在视图中传递Web 表。
你可能已经注意到, 表的本地化来自本地化文件夹。你可以在程序FastReport.Net的根目录中找到具有语言环境的文件夹。将其转移到你的项目。
另外,你需要将 表设计器添加到项目中。必须使用开发者 站(www.fast-report.com)客户端面板中使用特殊的在线构造函数构建它。之后,你将收到设计器的档案。将WebReportDesigner文件夹从此存档传送到此项目。
@{ ViewBag.Title = "Home Page";}@using (Html.BeginForm("Index","Home")){@Html.DropDownList("Language", new List<SelectListItem>(){ new SelectListItem(){ Text= "Russian", Value = "ru"}, new SelectListItem(){ Text= "English", Value = "en"}}, "Select language") <input type="submit" value="Select" />} @ViewBag.WebReport.GetHtml()
这里我们设置页面的标题。接下来,使用BeginForm助手来创建表单。其中,我们指定控制器和操作的方法。在表单中,我们创建了一个下拉列表,并填充了两个元素。请注意,Language列表的名称与Index方法中参数的名称相同。
此外,这里有一个按钮,我们接受选定的元素。最后,我们用@ViewBag显示我们的 表。
<head> @WebReportGlobals.Scripts() @WebReportGlobals.Styles()</head>
然后,在视图文件夹中有一个Web.config文件。给它添加命名空间:
<namespaces> <add namespace="FastReport" /> <add namespace="FastReport.Web" /> </namespaces>
在项目的根目录,还有另一个Web.config。在其中我们添加一个处理句柄,紧随模块部分之后:
<modules> … </modules> <handlers> <add name="FastReportHandler" path="FastReport.Export.axd" verb="*" type="FastReport.Web.Handlers.WebExport"/> </handlers>
现在你可以运行该应用程序:

选择俄语并点击“选择”按钮:

这样我们就得到了俄语的语言环境。如果你在预览中运行此 表,我们将在WebReport对象的工具栏中看到俄语:

就这样,我们完成了 表的本地化。我从列表中选择了语言,展示了最简单的本地化实现。要自动选择语言环境,可以使用Request.UserLanguages属性定义用户浏览器的语言。
产品介绍 | 下载试用 | 优惠活动 | 在线客服 | 联系Elyn
推荐阅读
- FastReport VCL 表控件开发者手册
- FastReport Online Designer中文手册
- Fastreport.Net教程2016
- Fastreport.Net用户手册
- FastReport.Net教程2017(持续更新中···)
- FastReport Online Designer教程2017(持续更新中···)
- 表教程2017(持续更新中···)
- FastReport.Net v2018.1版本更新已经发布!

标签: 表专家 表解决方案 表.NET 表控件 表设计 表引擎
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!